@capillarytech/creatives-library 8.0.255-alpha.4 → 8.0.255

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 (278) hide show
  1. package/assets/Android.png +0 -0
  2. package/assets/iOS.png +0 -0
  3. package/constants/unified.js +2 -2
  4. package/initialReducer.js +2 -0
  5. package/package.json +1 -1
  6. package/services/api.js +10 -5
  7. package/services/tests/api.test.js +34 -0
  8. package/translations/en.json +3 -4
  9. package/utils/common.js +5 -6
  10. package/utils/commonUtils.js +28 -5
  11. package/utils/tests/commonUtil.test.js +224 -0
  12. package/utils/tests/transformerUtils.test.js +0 -297
  13. package/utils/transformTemplateConfig.js +0 -10
  14. package/utils/transformerUtils.js +0 -40
  15. package/v2Components/CapDeviceContent/index.js +61 -56
  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 +6 -1
  21. package/v2Components/CapTagListWithInput/index.js +5 -1
  22. package/v2Components/CapTagListWithInput/messages.js +1 -1
  23. package/v2Components/CapWhatsappCTA/tests/index.test.js +5 -0
  24. package/v2Components/ErrorInfoNote/constants.js +1 -0
  25. package/v2Components/ErrorInfoNote/index.js +457 -72
  26. package/v2Components/ErrorInfoNote/messages.js +36 -6
  27. package/v2Components/ErrorInfoNote/style.scss +282 -6
  28. package/v2Components/FormBuilder/tests/index.test.js +13 -4
  29. package/v2Components/HtmlEditor/HTMLEditor.js +547 -94
  30. package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +874 -0
  31. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +1441 -133
  32. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +27 -16
  33. package/v2Components/HtmlEditor/_htmlEditor.scss +108 -45
  34. package/v2Components/HtmlEditor/_index.lazy.scss +0 -1
  35. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +23 -102
  36. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +148 -140
  37. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +2 -1
  38. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  39. package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +9 -0
  40. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +4 -4
  41. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +22 -0
  42. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +4 -7
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +35 -45
  44. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +1 -3
  45. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  46. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +7 -6
  47. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +3 -6
  48. package/v2Components/HtmlEditor/components/PreviewPane/index.js +22 -43
  49. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  50. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/_validationErrorDisplay.scss +1 -0
  51. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +49 -31
  52. package/v2Components/HtmlEditor/components/ValidationPanel/_validationPanel.scss +50 -34
  53. package/v2Components/HtmlEditor/components/ValidationPanel/constants.js +6 -0
  54. package/v2Components/HtmlEditor/components/ValidationPanel/index.js +70 -41
  55. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +255 -0
  56. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +364 -0
  57. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +51 -0
  58. package/v2Components/HtmlEditor/constants.js +42 -20
  59. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +373 -16
  60. package/v2Components/HtmlEditor/hooks/__tests__/useValidation.test.js +103 -0
  61. package/v2Components/HtmlEditor/hooks/useEditorContent.js +5 -2
  62. package/v2Components/HtmlEditor/hooks/useInAppContent.js +88 -146
  63. package/v2Components/HtmlEditor/hooks/useValidation.js +189 -53
  64. package/v2Components/HtmlEditor/index.js +1 -1
  65. package/v2Components/HtmlEditor/messages.js +92 -94
  66. package/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +94 -45
  67. package/v2Components/HtmlEditor/utils/__tests__/validationAdapter.test.js +134 -0
  68. package/v2Components/HtmlEditor/utils/contentSanitizer.js +40 -41
  69. package/v2Components/HtmlEditor/utils/htmlValidator.js +71 -72
  70. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +134 -102
  71. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +23 -25
  72. package/v2Components/HtmlEditor/utils/validationAdapter.js +66 -41
  73. package/v2Components/HtmlEditor/utils/validationConstants.js +40 -0
  74. package/v2Components/MobilePushPreviewV2/index.js +32 -7
  75. package/v2Components/TemplatePreview/_templatePreview.scss +55 -24
  76. package/v2Components/TemplatePreview/index.js +47 -32
  77. package/v2Components/TemplatePreview/messages.js +4 -0
  78. package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +1 -0
  79. package/v2Containers/App/constants.js +0 -5
  80. package/v2Containers/BeeEditor/index.js +172 -90
  81. package/v2Containers/BeePopupEditor/_beePopupEditor.scss +14 -0
  82. package/v2Containers/BeePopupEditor/constants.js +10 -0
  83. package/v2Containers/BeePopupEditor/index.js +194 -0
  84. package/v2Containers/BeePopupEditor/tests/index.test.js +627 -0
  85. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +3 -4
  86. package/v2Containers/CreativesContainer/SlideBoxContent.js +129 -107
  87. package/v2Containers/CreativesContainer/SlideBoxFooter.js +163 -13
  88. package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
  89. package/v2Containers/CreativesContainer/constants.js +1 -3
  90. package/v2Containers/CreativesContainer/index.js +239 -214
  91. package/v2Containers/CreativesContainer/messages.js +8 -4
  92. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +0 -210
  93. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +11 -2
  94. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +38 -354
  95. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +106 -0
  96. package/v2Containers/Email/actions.js +7 -0
  97. package/v2Containers/Email/constants.js +5 -1
  98. package/v2Containers/Email/index.js +234 -29
  99. package/v2Containers/Email/messages.js +32 -0
  100. package/v2Containers/Email/reducer.js +12 -1
  101. package/v2Containers/Email/sagas.js +61 -7
  102. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +2 -0
  103. package/v2Containers/Email/tests/reducer.test.js +46 -0
  104. package/v2Containers/Email/tests/sagas.test.js +320 -29
  105. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +1285 -0
  106. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +211 -21
  107. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +40 -74
  108. package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +1880 -0
  109. package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +520 -0
  110. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +2 -67
  111. package/v2Containers/EmailWrapper/constants.js +2 -0
  112. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +629 -77
  113. package/v2Containers/EmailWrapper/index.js +103 -23
  114. package/v2Containers/EmailWrapper/messages.js +65 -1
  115. package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +643 -0
  116. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +594 -77
  117. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +376 -0
  118. package/v2Containers/InApp/__tests__/sagas.test.js +363 -0
  119. package/v2Containers/InApp/actions.js +7 -0
  120. package/v2Containers/InApp/constants.js +20 -4
  121. package/v2Containers/InApp/index.js +802 -359
  122. package/v2Containers/InApp/index.scss +4 -3
  123. package/v2Containers/InApp/messages.js +7 -3
  124. package/v2Containers/InApp/reducer.js +21 -3
  125. package/v2Containers/InApp/sagas.js +29 -9
  126. package/v2Containers/InApp/selectors.js +25 -5
  127. package/v2Containers/InApp/tests/index.test.js +154 -50
  128. package/v2Containers/InApp/tests/reducer.test.js +34 -0
  129. package/v2Containers/InApp/tests/sagas.test.js +61 -9
  130. package/v2Containers/InApp/tests/selectors.test.js +612 -0
  131. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +151 -0
  132. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +267 -0
  133. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +23 -0
  134. package/v2Containers/InAppWrapper/constants.js +16 -0
  135. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +473 -0
  136. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +198 -0
  137. package/v2Containers/InAppWrapper/index.js +148 -0
  138. package/v2Containers/InAppWrapper/messages.js +49 -0
  139. package/v2Containers/InappAdvance/index.js +1099 -0
  140. package/v2Containers/InappAdvance/index.scss +10 -0
  141. package/v2Containers/InappAdvance/tests/index.test.js +448 -0
  142. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +15 -36
  143. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +8 -8
  144. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +77 -100
  145. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +63 -72
  146. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +190 -250
  147. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +12 -16
  148. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +40 -48
  149. package/v2Containers/TagList/index.js +62 -19
  150. package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
  151. package/v2Containers/Templates/_templates.scss +56 -202
  152. package/v2Containers/Templates/actions.js +1 -2
  153. package/v2Containers/Templates/constants.js +0 -1
  154. package/v2Containers/Templates/index.js +123 -278
  155. package/v2Containers/Templates/messages.js +4 -24
  156. package/v2Containers/Templates/reducer.js +0 -2
  157. package/v2Containers/Templates/tests/index.test.js +0 -10
  158. package/v2Containers/TemplatesV2/index.js +7 -15
  159. package/v2Containers/TemplatesV2/messages.js +0 -4
  160. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +768 -1272
  161. package/utils/imageUrlUpload.js +0 -141
  162. package/v2Components/CapImageUrlUpload/constants.js +0 -26
  163. package/v2Components/CapImageUrlUpload/index.js +0 -365
  164. package/v2Components/CapImageUrlUpload/index.scss +0 -35
  165. package/v2Components/CapImageUrlUpload/messages.js +0 -47
  166. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +0 -152
  167. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +0 -214
  168. package/v2Containers/WebPush/Create/components/BrandIconSection.js +0 -108
  169. package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -172
  170. package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
  171. package/v2Containers/WebPush/Create/components/ButtonList.js +0 -145
  172. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +0 -164
  173. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +0 -463
  174. package/v2Containers/WebPush/Create/components/FormActions.js +0 -54
  175. package/v2Containers/WebPush/Create/components/FormActions.test.js +0 -163
  176. package/v2Containers/WebPush/Create/components/MediaSection.js +0 -142
  177. package/v2Containers/WebPush/Create/components/MediaSection.test.js +0 -341
  178. package/v2Containers/WebPush/Create/components/MessageSection.js +0 -103
  179. package/v2Containers/WebPush/Create/components/MessageSection.test.js +0 -268
  180. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +0 -87
  181. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +0 -210
  182. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +0 -54
  183. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +0 -143
  184. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +0 -86
  185. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +0 -16
  186. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +0 -41
  187. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +0 -54
  188. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +0 -37
  189. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +0 -21
  190. package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
  191. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
  192. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
  193. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -633
  194. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
  195. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
  196. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -78
  197. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +0 -138
  198. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +0 -406
  199. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +0 -30
  200. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +0 -151
  201. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +0 -104
  202. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +0 -538
  203. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +0 -122
  204. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +0 -633
  205. package/v2Containers/WebPush/Create/index.js +0 -1148
  206. package/v2Containers/WebPush/Create/index.scss +0 -134
  207. package/v2Containers/WebPush/Create/messages.js +0 -203
  208. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -228
  209. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -294
  210. package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -90
  211. package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -305
  212. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -23
  213. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -155
  214. package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
  215. package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
  216. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +0 -9
  217. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +0 -9
  218. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  219. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  220. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
  221. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
  222. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +0 -9
  223. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +0 -9
  224. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
  225. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
  226. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +0 -9
  227. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +0 -9
  228. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -47
  229. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -141
  230. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
  231. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -68
  232. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -61
  233. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -99
  234. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -733
  235. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +0 -571
  236. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -81
  237. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +0 -81
  238. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -50
  239. package/v2Containers/WebPush/Create/preview/constants.js +0 -637
  240. package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -79
  241. package/v2Containers/WebPush/Create/preview/preview.scss +0 -351
  242. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -370
  243. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
  244. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
  245. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
  246. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -47
  247. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
  248. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
  249. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
  250. package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -207
  251. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -153
  252. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
  253. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -101
  254. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -229
  255. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -909
  256. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1081
  257. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
  258. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -1327
  259. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -131
  260. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -112
  261. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
  262. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -129
  263. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +0 -96
  264. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +0 -396
  265. package/v2Containers/WebPush/Create/utils/previewUtils.js +0 -89
  266. package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -115
  267. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
  268. package/v2Containers/WebPush/Create/utils/validation.js +0 -75
  269. package/v2Containers/WebPush/Create/utils/validation.test.js +0 -283
  270. package/v2Containers/WebPush/actions.js +0 -60
  271. package/v2Containers/WebPush/constants.js +0 -132
  272. package/v2Containers/WebPush/index.js +0 -2
  273. package/v2Containers/WebPush/reducer.js +0 -104
  274. package/v2Containers/WebPush/sagas.js +0 -119
  275. package/v2Containers/WebPush/selectors.js +0 -65
  276. package/v2Containers/WebPush/tests/reducer.test.js +0 -863
  277. package/v2Containers/WebPush/tests/sagas.test.js +0 -566
  278. package/v2Containers/WebPush/tests/selectors.test.js +0 -960
@@ -1,566 +0,0 @@
1
- import { expectSaga } from 'redux-saga-test-plan';
2
- import { call } from 'redux-saga/effects';
3
- import { throwError } from 'redux-saga-test-plan/providers';
4
- import * as Api from '../../../services/api';
5
- import * as sagas from '../sagas';
6
- import * as types from '../constants';
7
-
8
- describe('WebPush Sagas', () => {
9
- describe('createTemplate', () => {
10
- const template = { name: 'Test Template', content: 'Test Content' };
11
- const callback = jest.fn();
12
-
13
- beforeEach(() => {
14
- jest.clearAllMocks();
15
- });
16
-
17
- it('should handle successful template creation without callback', () => {
18
- const fakeResponse = {
19
- status: { code: 200 },
20
- response: { id: 1, name: 'Test Template' },
21
- };
22
-
23
- return expectSaga(sagas.createTemplate, { template })
24
- .provide([
25
- [call(Api.createWebPushTemplate, template), fakeResponse],
26
- ])
27
- .put({
28
- type: types.CREATE_TEMPLATE_SUCCESS,
29
- data: fakeResponse.response,
30
- statusCode: 200,
31
- errorMsg: undefined,
32
- })
33
- .run();
34
- });
35
-
36
- it('should handle successful template creation with callback', () => {
37
- const fakeResponse = {
38
- status: { code: 201 },
39
- response: { id: 1, name: 'Test Template' },
40
- };
41
-
42
- return expectSaga(sagas.createTemplate, { template, callback })
43
- .provide([
44
- [call(Api.createWebPushTemplate, template), fakeResponse],
45
- [call(callback, fakeResponse.response), undefined],
46
- ])
47
- .put({
48
- type: types.CREATE_TEMPLATE_SUCCESS,
49
- data: fakeResponse.response,
50
- statusCode: 201,
51
- errorMsg: undefined,
52
- })
53
- .run();
54
- });
55
-
56
- it('should handle template creation with error message but status < 400', () => {
57
- const fakeResponse = {
58
- status: { code: 200 },
59
- response: { id: 1, name: 'Test Template' },
60
- message: 'Warning message',
61
- };
62
-
63
- return expectSaga(sagas.createTemplate, { template, callback })
64
- .provide([
65
- [call(Api.createWebPushTemplate, template), fakeResponse],
66
- [call(callback, fakeResponse.response), undefined],
67
- ])
68
- .put({
69
- type: types.CREATE_TEMPLATE_SUCCESS,
70
- data: fakeResponse.response,
71
- statusCode: 200,
72
- errorMsg: 'Warning message',
73
- })
74
- .run();
75
- });
76
-
77
- it('should handle template creation failure with status >= 400', () => {
78
- const errorMsg = 'Bad Request';
79
- const fakeResponse = {
80
- status: { code: 400 },
81
- message: errorMsg,
82
- };
83
-
84
- return expectSaga(sagas.createTemplate, { template, callback })
85
- .provide([
86
- [call(Api.createWebPushTemplate, template), fakeResponse],
87
- ])
88
- .put({
89
- type: types.CREATE_TEMPLATE_FAILURE,
90
- error: errorMsg,
91
- errorMsg,
92
- })
93
- .run();
94
- });
95
-
96
- it('should handle template creation failure with status >= 400 and no message', () => {
97
- const fakeResponse = {
98
- status: { code: 500 },
99
- };
100
-
101
- return expectSaga(sagas.createTemplate, { template, callback })
102
- .provide([
103
- [call(Api.createWebPushTemplate, template), fakeResponse],
104
- ])
105
- .put({
106
- type: types.CREATE_TEMPLATE_FAILURE,
107
- error: undefined,
108
- errorMsg: undefined,
109
- })
110
- .run();
111
- });
112
-
113
- it('should handle template creation with API exception', () => {
114
- const error = new Error('Network error');
115
-
116
- return expectSaga(sagas.createTemplate, { template, callback })
117
- .provide([
118
- [call(Api.createWebPushTemplate, template), throwError(error)],
119
- ])
120
- .put({
121
- type: types.CREATE_TEMPLATE_FAILURE,
122
- error,
123
- errorMsg: undefined,
124
- })
125
- .run();
126
- });
127
-
128
- it('should handle template creation without status object', () => {
129
- const fakeResponse = {
130
- response: { id: 1, name: 'Test Template' },
131
- };
132
-
133
- return expectSaga(sagas.createTemplate, { template })
134
- .provide([
135
- [call(Api.createWebPushTemplate, template), fakeResponse],
136
- ])
137
- .put({
138
- type: types.CREATE_TEMPLATE_SUCCESS,
139
- data: fakeResponse.response,
140
- statusCode: '',
141
- errorMsg: undefined,
142
- })
143
- .run();
144
- });
145
- });
146
-
147
- describe('clearCreateResponse', () => {
148
- it('should dispatch CLEAR_CREATE_RESPONSE_SUCCESS action', () => {
149
- return expectSaga(sagas.clearCreateResponse)
150
- .put({
151
- type: types.CLEAR_CREATE_RESPONSE_SUCCESS,
152
- })
153
- .run();
154
- });
155
- });
156
-
157
- describe('editTemplate', () => {
158
- const template = { id: 1, name: 'Updated Template', content: 'Updated Content' };
159
- const callback = jest.fn();
160
-
161
- beforeEach(() => {
162
- jest.clearAllMocks();
163
- });
164
-
165
- it('should handle successful template edit without callback', () => {
166
- const fakeResponse = {
167
- status: { code: 200 },
168
- response: { id: 1, name: 'Updated Template' },
169
- };
170
-
171
- return expectSaga(sagas.editTemplate, { template })
172
- .provide([
173
- [call(Api.createWebPushTemplate, template), fakeResponse],
174
- ])
175
- .put({
176
- type: types.EDIT_TEMPLATE_SUCCESS,
177
- data: fakeResponse.response,
178
- statusCode: 200,
179
- errorMsg: undefined,
180
- })
181
- .run();
182
- });
183
-
184
- it('should handle successful template edit with callback', () => {
185
- const fakeResponse = {
186
- status: { code: 200 },
187
- response: { id: 1, name: 'Updated Template' },
188
- };
189
-
190
- return expectSaga(sagas.editTemplate, { template, callback })
191
- .provide([
192
- [call(Api.createWebPushTemplate, template), fakeResponse],
193
- ])
194
- .put({
195
- type: types.EDIT_TEMPLATE_SUCCESS,
196
- data: fakeResponse.response,
197
- statusCode: 200,
198
- errorMsg: undefined,
199
- })
200
- .run()
201
- .then(() => {
202
- expect(callback).toHaveBeenCalledWith(fakeResponse.response, undefined);
203
- });
204
- });
205
-
206
- it('should handle template edit with error message but status < 400', () => {
207
- const fakeResponse = {
208
- status: { code: 200 },
209
- response: { id: 1, name: 'Updated Template' },
210
- message: 'Warning message',
211
- };
212
-
213
- return expectSaga(sagas.editTemplate, { template, callback })
214
- .provide([
215
- [call(Api.createWebPushTemplate, template), fakeResponse],
216
- ])
217
- .put({
218
- type: types.EDIT_TEMPLATE_SUCCESS,
219
- data: fakeResponse.response,
220
- statusCode: 200,
221
- errorMsg: 'Warning message',
222
- })
223
- .run()
224
- .then(() => {
225
- expect(callback).toHaveBeenCalledWith(fakeResponse.response, 'Warning message');
226
- });
227
- });
228
-
229
- it('should handle template edit failure with status >= 400', () => {
230
- const errorMsg = 'Bad Request';
231
- const fakeResponse = {
232
- status: { code: 400 },
233
- message: errorMsg,
234
- };
235
-
236
- return expectSaga(sagas.editTemplate, { template, callback })
237
- .provide([
238
- [call(Api.createWebPushTemplate, template), fakeResponse],
239
- ])
240
- .put({
241
- type: types.EDIT_TEMPLATE_FAILURE,
242
- error: errorMsg,
243
- errorMsg,
244
- })
245
- .run()
246
- .then(() => {
247
- expect(callback).toHaveBeenCalledWith(null, errorMsg);
248
- });
249
- });
250
-
251
- it('should handle template edit failure with status >= 400 and no callback', () => {
252
- const errorMsg = 'Bad Request';
253
- const fakeResponse = {
254
- status: { code: 500 },
255
- message: errorMsg,
256
- };
257
-
258
- return expectSaga(sagas.editTemplate, { template })
259
- .provide([
260
- [call(Api.createWebPushTemplate, template), fakeResponse],
261
- ])
262
- .put({
263
- type: types.EDIT_TEMPLATE_FAILURE,
264
- error: errorMsg,
265
- errorMsg,
266
- })
267
- .run();
268
- });
269
-
270
- it('should handle template edit with API exception and callback', () => {
271
- const error = new Error('Network error');
272
-
273
- return expectSaga(sagas.editTemplate, { template, callback })
274
- .provide([
275
- [call(Api.createWebPushTemplate, template), throwError(error)],
276
- ])
277
- .put({
278
- type: types.EDIT_TEMPLATE_FAILURE,
279
- error,
280
- errorMsg: undefined,
281
- })
282
- .run()
283
- .then(() => {
284
- expect(callback).toHaveBeenCalledWith(null, undefined);
285
- });
286
- });
287
-
288
- it('should handle template edit with API exception without callback', () => {
289
- const error = new Error('Network error');
290
-
291
- return expectSaga(sagas.editTemplate, { template })
292
- .provide([
293
- [call(Api.createWebPushTemplate, template), throwError(error)],
294
- ])
295
- .put({
296
- type: types.EDIT_TEMPLATE_FAILURE,
297
- error,
298
- errorMsg: undefined,
299
- })
300
- .run();
301
- });
302
-
303
- it('should handle template edit without status object', () => {
304
- const fakeResponse = {
305
- response: { id: 1, name: 'Updated Template' },
306
- };
307
-
308
- return expectSaga(sagas.editTemplate, { template })
309
- .provide([
310
- [call(Api.createWebPushTemplate, template), fakeResponse],
311
- ])
312
- .put({
313
- type: types.EDIT_TEMPLATE_SUCCESS,
314
- data: fakeResponse.response,
315
- statusCode: '',
316
- errorMsg: undefined,
317
- })
318
- .run();
319
- });
320
- });
321
-
322
- describe('clearEditResponse', () => {
323
- it('should dispatch CLEAR_EDIT_RESPONSE_SUCCESS action', () => {
324
- return expectSaga(sagas.clearEditResponse)
325
- .put({
326
- type: types.CLEAR_EDIT_RESPONSE_SUCCESS,
327
- })
328
- .run();
329
- });
330
- });
331
-
332
- describe('uploadWebPushAsset', () => {
333
- const file = new Blob(['file contents'], { type: 'image/png' });
334
- const assetType = 'image';
335
- const fileParams = { width: 100, height: 100 };
336
- const templateType = 'rich';
337
-
338
- it('should handle successful asset upload', () => {
339
- const fakeResponse = {
340
- status: { code: 200 },
341
- response: {
342
- asset: {
343
- id: 1,
344
- url: 'https://example.com/image.png',
345
- },
346
- },
347
- };
348
-
349
- return expectSaga(sagas.uploadWebPushAsset, {
350
- file,
351
- assetType,
352
- fileParams,
353
- templateType,
354
- })
355
- .provide([
356
- [
357
- call(Api.uploadFile, {
358
- file,
359
- assetType,
360
- fileParams,
361
- }),
362
- fakeResponse,
363
- ],
364
- ])
365
- .put({
366
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
367
- data: fakeResponse.response.asset,
368
- statusCode: 200,
369
- templateType,
370
- })
371
- .run();
372
- });
373
-
374
- it('should handle asset upload without templateType', () => {
375
- const fakeResponse = {
376
- status: { code: 201 },
377
- response: {
378
- asset: {
379
- id: 1,
380
- url: 'https://example.com/image.png',
381
- },
382
- },
383
- };
384
-
385
- return expectSaga(sagas.uploadWebPushAsset, {
386
- file,
387
- assetType,
388
- fileParams,
389
- })
390
- .provide([
391
- [
392
- call(Api.uploadFile, {
393
- file,
394
- assetType,
395
- fileParams,
396
- }),
397
- fakeResponse,
398
- ],
399
- ])
400
- .put({
401
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
402
- data: fakeResponse.response.asset,
403
- statusCode: 201,
404
- templateType: undefined,
405
- })
406
- .run();
407
- });
408
-
409
- it('should handle asset upload without status object', () => {
410
- const fakeResponse = {
411
- response: {
412
- asset: {
413
- id: 1,
414
- url: 'https://example.com/image.png',
415
- },
416
- },
417
- };
418
-
419
- return expectSaga(sagas.uploadWebPushAsset, {
420
- file,
421
- assetType,
422
- fileParams,
423
- templateType,
424
- })
425
- .provide([
426
- [
427
- call(Api.uploadFile, {
428
- file,
429
- assetType,
430
- fileParams,
431
- }),
432
- fakeResponse,
433
- ],
434
- ])
435
- .put({
436
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
437
- data: fakeResponse.response.asset,
438
- statusCode: '',
439
- templateType,
440
- })
441
- .run();
442
- });
443
-
444
- it('should handle asset upload with null response', () => {
445
- const fakeResponse = {
446
- status: { code: 200 },
447
- response: null,
448
- };
449
-
450
- return expectSaga(sagas.uploadWebPushAsset, {
451
- file,
452
- assetType,
453
- fileParams,
454
- templateType,
455
- })
456
- .provide([
457
- [
458
- call(Api.uploadFile, {
459
- file,
460
- assetType,
461
- fileParams,
462
- }),
463
- fakeResponse,
464
- ],
465
- ])
466
- .put({
467
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
468
- data: undefined,
469
- statusCode: 200,
470
- templateType,
471
- })
472
- .run();
473
- });
474
-
475
- it('should handle asset upload failure', () => {
476
- const error = new Error('Upload failed');
477
-
478
- return expectSaga(sagas.uploadWebPushAsset, {
479
- file,
480
- assetType,
481
- fileParams,
482
- templateType,
483
- })
484
- .provide([
485
- [
486
- call(Api.uploadFile, {
487
- file,
488
- assetType,
489
- fileParams,
490
- }),
491
- throwError(error),
492
- ],
493
- ])
494
- .put({
495
- type: types.UPLOAD_WEBPUSH_ASSET_FAILURE,
496
- error,
497
- })
498
- .run();
499
- });
500
-
501
- it('should handle asset upload with undefined response', () => {
502
- const fakeResponse = undefined;
503
-
504
- return expectSaga(sagas.uploadWebPushAsset, {
505
- file,
506
- assetType,
507
- fileParams,
508
- templateType,
509
- })
510
- .provide([
511
- [
512
- call(Api.uploadFile, {
513
- file,
514
- assetType,
515
- fileParams,
516
- }),
517
- fakeResponse,
518
- ],
519
- ])
520
- .put({
521
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
522
- data: undefined,
523
- statusCode: '',
524
- templateType,
525
- })
526
- .run();
527
- });
528
- });
529
-
530
- describe('watchCreateTemplate', () => {
531
- it.concurrent('should initialize watchCreateTemplate watcher saga without error', () => {
532
- return expectSaga(sagas.watchCreateTemplate).run();
533
- });
534
- });
535
-
536
- describe('watchClearCreateResponse', () => {
537
- it.concurrent('should initialize watchClearCreateResponse watcher saga without error', () => {
538
- return expectSaga(sagas.watchClearCreateResponse).run();
539
- });
540
- });
541
-
542
- describe('watchEditTemplate', () => {
543
- it.concurrent('should initialize watchEditTemplate watcher saga without error', () => {
544
- return expectSaga(sagas.watchEditTemplate).run();
545
- });
546
- });
547
-
548
- describe('watchClearEditResponse', () => {
549
- it.concurrent('should initialize watchClearEditResponse watcher saga without error', () => {
550
- return expectSaga(sagas.watchClearEditResponse).run();
551
- });
552
- });
553
-
554
- describe('watchUploadWebPushAsset', () => {
555
- it.concurrent('should initialize watchUploadWebPushAsset watcher saga without error', () => {
556
- return expectSaga(sagas.watchUploadWebPushAsset).run();
557
- });
558
- });
559
-
560
- describe('webPushSagas (default export)', () => {
561
- it.concurrent('should initialize all webPushSagas watcher sagas without error', () => {
562
- return expectSaga(sagas.default).run();
563
- });
564
- });
565
- });
566
-