@capillarytech/creatives-library 8.0.257 → 8.0.258

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 +0 -2
  5. package/package.json +1 -1
  6. package/services/api.js +5 -10
  7. package/services/tests/api.test.js +0 -34
  8. package/translations/en.json +4 -3
  9. package/utils/common.js +6 -5
  10. package/utils/commonUtils.js +5 -28
  11. package/utils/imageUrlUpload.js +141 -0
  12. package/utils/tests/commonUtil.test.js +0 -224
  13. package/utils/tests/transformerUtils.test.js +297 -0
  14. package/utils/transformTemplateConfig.js +10 -0
  15. package/utils/transformerUtils.js +40 -0
  16. package/v2Components/CapDeviceContent/index.js +56 -61
  17. package/v2Components/CapImageUpload/constants.js +2 -0
  18. package/v2Components/CapImageUpload/index.js +65 -16
  19. package/v2Components/CapImageUpload/index.scss +4 -1
  20. package/v2Components/CapImageUpload/messages.js +5 -1
  21. package/v2Components/CapImageUrlUpload/constants.js +26 -0
  22. package/v2Components/CapImageUrlUpload/index.js +365 -0
  23. package/v2Components/CapImageUrlUpload/index.scss +35 -0
  24. package/v2Components/CapImageUrlUpload/messages.js +47 -0
  25. package/v2Components/CapTagList/index.js +1 -6
  26. package/v2Components/CapTagListWithInput/index.js +1 -5
  27. package/v2Components/CapTagListWithInput/messages.js +1 -1
  28. package/v2Components/CapWhatsappCTA/tests/index.test.js +0 -5
  29. package/v2Components/ErrorInfoNote/index.js +72 -457
  30. package/v2Components/ErrorInfoNote/messages.js +6 -36
  31. package/v2Components/ErrorInfoNote/style.scss +6 -282
  32. package/v2Components/FormBuilder/tests/index.test.js +4 -13
  33. package/v2Components/HtmlEditor/HTMLEditor.js +94 -547
  34. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +133 -1441
  35. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +16 -27
  36. package/v2Components/HtmlEditor/_htmlEditor.scss +45 -108
  37. package/v2Components/HtmlEditor/_index.lazy.scss +1 -0
  38. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +102 -23
  39. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +140 -148
  40. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +1 -2
  41. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  42. package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +0 -9
  43. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +4 -4
  44. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -22
  45. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
  46. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
  47. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
  48. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  49. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
  50. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +6 -3
  51. package/v2Components/HtmlEditor/components/PreviewPane/index.js +43 -22
  52. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  53. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +152 -0
  54. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/_validationErrorDisplay.scss +0 -1
  55. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -49
  56. package/v2Components/HtmlEditor/components/ValidationPanel/_validationPanel.scss +34 -50
  57. package/v2Components/HtmlEditor/components/ValidationPanel/index.js +41 -70
  58. package/v2Components/HtmlEditor/constants.js +20 -42
  59. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +16 -373
  60. package/v2Components/HtmlEditor/hooks/__tests__/useValidation.test.js +0 -103
  61. package/v2Components/HtmlEditor/hooks/useEditorContent.js +2 -5
  62. package/v2Components/HtmlEditor/hooks/useInAppContent.js +146 -88
  63. package/v2Components/HtmlEditor/hooks/useValidation.js +53 -189
  64. package/v2Components/HtmlEditor/index.js +1 -1
  65. package/v2Components/HtmlEditor/messages.js +94 -92
  66. package/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +45 -94
  67. package/v2Components/HtmlEditor/utils/__tests__/validationAdapter.test.js +0 -134
  68. package/v2Components/HtmlEditor/utils/contentSanitizer.js +41 -40
  69. package/v2Components/HtmlEditor/utils/htmlValidator.js +72 -71
  70. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +102 -134
  71. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
  72. package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -66
  73. package/v2Components/MobilePushPreviewV2/index.js +7 -32
  74. package/v2Components/TemplatePreview/_templatePreview.scss +24 -55
  75. package/v2Components/TemplatePreview/index.js +32 -47
  76. package/v2Components/TemplatePreview/messages.js +0 -4
  77. package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +0 -1
  78. package/v2Containers/App/constants.js +5 -0
  79. package/v2Containers/BeeEditor/index.js +90 -172
  80. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +4 -3
  81. package/v2Containers/CreativesContainer/SlideBoxContent.js +107 -129
  82. package/v2Containers/CreativesContainer/SlideBoxFooter.js +13 -163
  83. package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
  84. package/v2Containers/CreativesContainer/constants.js +3 -1
  85. package/v2Containers/CreativesContainer/index.js +214 -239
  86. package/v2Containers/CreativesContainer/messages.js +4 -8
  87. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +210 -0
  88. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +2 -11
  89. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +354 -38
  90. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -106
  91. package/v2Containers/Email/actions.js +0 -7
  92. package/v2Containers/Email/constants.js +1 -5
  93. package/v2Containers/Email/index.js +29 -234
  94. package/v2Containers/Email/messages.js +0 -32
  95. package/v2Containers/Email/reducer.js +1 -12
  96. package/v2Containers/Email/sagas.js +7 -61
  97. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
  98. package/v2Containers/Email/tests/reducer.test.js +0 -46
  99. package/v2Containers/Email/tests/sagas.test.js +29 -320
  100. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +21 -211
  101. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
  102. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
  103. package/v2Containers/EmailWrapper/constants.js +0 -2
  104. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +77 -629
  105. package/v2Containers/EmailWrapper/index.js +23 -103
  106. package/v2Containers/EmailWrapper/messages.js +1 -65
  107. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +214 -0
  108. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -594
  109. package/v2Containers/InApp/actions.js +0 -7
  110. package/v2Containers/InApp/constants.js +4 -20
  111. package/v2Containers/InApp/index.js +359 -802
  112. package/v2Containers/InApp/index.scss +3 -4
  113. package/v2Containers/InApp/messages.js +3 -7
  114. package/v2Containers/InApp/reducer.js +3 -21
  115. package/v2Containers/InApp/sagas.js +9 -29
  116. package/v2Containers/InApp/selectors.js +5 -25
  117. package/v2Containers/InApp/tests/index.test.js +50 -154
  118. package/v2Containers/InApp/tests/reducer.test.js +0 -34
  119. package/v2Containers/InApp/tests/sagas.test.js +9 -61
  120. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +36 -15
  121. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +8 -8
  122. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +100 -77
  123. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +72 -63
  124. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +250 -190
  125. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +16 -12
  126. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +48 -40
  127. package/v2Containers/TagList/index.js +19 -62
  128. package/v2Containers/Templates/ChannelTypeIllustration.js +13 -1
  129. package/v2Containers/Templates/_templates.scss +202 -56
  130. package/v2Containers/Templates/actions.js +2 -1
  131. package/v2Containers/Templates/constants.js +1 -0
  132. package/v2Containers/Templates/index.js +278 -123
  133. package/v2Containers/Templates/messages.js +24 -4
  134. package/v2Containers/Templates/reducer.js +2 -0
  135. package/v2Containers/Templates/tests/index.test.js +10 -0
  136. package/v2Containers/TemplatesV2/index.js +15 -7
  137. package/v2Containers/TemplatesV2/messages.js +4 -0
  138. package/v2Containers/WebPush/Create/components/BrandIconSection.js +108 -0
  139. package/v2Containers/WebPush/Create/components/ButtonForm.js +172 -0
  140. package/v2Containers/WebPush/Create/components/ButtonItem.js +101 -0
  141. package/v2Containers/WebPush/Create/components/ButtonList.js +145 -0
  142. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +164 -0
  143. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +463 -0
  144. package/v2Containers/WebPush/Create/components/FormActions.js +54 -0
  145. package/v2Containers/WebPush/Create/components/FormActions.test.js +163 -0
  146. package/v2Containers/WebPush/Create/components/MediaSection.js +142 -0
  147. package/v2Containers/WebPush/Create/components/MediaSection.test.js +341 -0
  148. package/v2Containers/WebPush/Create/components/MessageSection.js +103 -0
  149. package/v2Containers/WebPush/Create/components/MessageSection.test.js +268 -0
  150. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +87 -0
  151. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +210 -0
  152. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +54 -0
  153. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +143 -0
  154. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +86 -0
  155. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +16 -0
  156. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +41 -0
  157. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +54 -0
  158. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +37 -0
  159. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +21 -0
  160. package/v2Containers/WebPush/Create/components/_buttons.scss +246 -0
  161. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +554 -0
  162. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +607 -0
  163. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +633 -0
  164. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +666 -0
  165. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +74 -0
  166. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +78 -0
  167. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +138 -0
  168. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +406 -0
  169. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +30 -0
  170. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +151 -0
  171. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +104 -0
  172. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +538 -0
  173. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +122 -0
  174. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +633 -0
  175. package/v2Containers/WebPush/Create/index.js +1148 -0
  176. package/v2Containers/WebPush/Create/index.scss +134 -0
  177. package/v2Containers/WebPush/Create/messages.js +203 -0
  178. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +228 -0
  179. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +294 -0
  180. package/v2Containers/WebPush/Create/preview/PreviewContent.js +90 -0
  181. package/v2Containers/WebPush/Create/preview/PreviewControls.js +305 -0
  182. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +23 -0
  183. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +155 -0
  184. package/v2Containers/WebPush/Create/preview/assets/Light.svg +53 -0
  185. package/v2Containers/WebPush/Create/preview/assets/Top.svg +5 -0
  186. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +9 -0
  187. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +9 -0
  188. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  189. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  190. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +106 -0
  191. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +26 -0
  192. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +9 -0
  193. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +9 -0
  194. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +18 -0
  195. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +29 -0
  196. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +9 -0
  197. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +9 -0
  198. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +47 -0
  199. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +141 -0
  200. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +45 -0
  201. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +68 -0
  202. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +61 -0
  203. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +99 -0
  204. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +733 -0
  205. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +571 -0
  206. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +81 -0
  207. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +81 -0
  208. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +50 -0
  209. package/v2Containers/WebPush/Create/preview/constants.js +637 -0
  210. package/v2Containers/WebPush/Create/preview/notification-container.scss +79 -0
  211. package/v2Containers/WebPush/Create/preview/preview.scss +351 -0
  212. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +370 -0
  213. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +12 -0
  214. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +12 -0
  215. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +12 -0
  216. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +47 -0
  217. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +11 -0
  218. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +11 -0
  219. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +11 -0
  220. package/v2Containers/WebPush/Create/preview/styles/_base.scss +207 -0
  221. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +153 -0
  222. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +107 -0
  223. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +101 -0
  224. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +229 -0
  225. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +909 -0
  226. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +1081 -0
  227. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +723 -0
  228. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +1327 -0
  229. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +131 -0
  230. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +112 -0
  231. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +144 -0
  232. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +129 -0
  233. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +96 -0
  234. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +396 -0
  235. package/v2Containers/WebPush/Create/utils/previewUtils.js +89 -0
  236. package/v2Containers/WebPush/Create/utils/urlValidation.js +115 -0
  237. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +449 -0
  238. package/v2Containers/WebPush/Create/utils/validation.js +75 -0
  239. package/v2Containers/WebPush/Create/utils/validation.test.js +283 -0
  240. package/v2Containers/WebPush/actions.js +60 -0
  241. package/v2Containers/WebPush/constants.js +132 -0
  242. package/v2Containers/WebPush/index.js +2 -0
  243. package/v2Containers/WebPush/reducer.js +104 -0
  244. package/v2Containers/WebPush/sagas.js +119 -0
  245. package/v2Containers/WebPush/selectors.js +65 -0
  246. package/v2Containers/WebPush/tests/reducer.test.js +863 -0
  247. package/v2Containers/WebPush/tests/sagas.test.js +566 -0
  248. package/v2Containers/WebPush/tests/selectors.test.js +960 -0
  249. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +1272 -768
  250. package/v2Components/ErrorInfoNote/constants.js +0 -1
  251. package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +0 -874
  252. package/v2Components/HtmlEditor/components/ValidationPanel/constants.js +0 -6
  253. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -255
  254. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -364
  255. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
  256. package/v2Components/HtmlEditor/utils/validationConstants.js +0 -40
  257. package/v2Containers/BeePopupEditor/_beePopupEditor.scss +0 -14
  258. package/v2Containers/BeePopupEditor/constants.js +0 -10
  259. package/v2Containers/BeePopupEditor/index.js +0 -194
  260. package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
  261. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1285
  262. package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +0 -1880
  263. package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +0 -520
  264. package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +0 -643
  265. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
  266. package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
  267. package/v2Containers/InApp/tests/selectors.test.js +0 -612
  268. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -151
  269. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
  270. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -23
  271. package/v2Containers/InAppWrapper/constants.js +0 -16
  272. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
  273. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
  274. package/v2Containers/InAppWrapper/index.js +0 -148
  275. package/v2Containers/InAppWrapper/messages.js +0 -49
  276. package/v2Containers/InappAdvance/index.js +0 -1099
  277. package/v2Containers/InappAdvance/index.scss +0 -10
  278. package/v2Containers/InappAdvance/tests/index.test.js +0 -448
@@ -1,14 +0,0 @@
1
- @import '~@capillarytech/cap-ui-library/styles/_variables.scss';
2
-
3
- .bee-popup-editor {
4
- &__container {
5
- height: 46.5rem;
6
- }
7
- }
8
-
9
- .bee-editor-tag-list {
10
- &--positioned {
11
- left: 9.643rem;
12
- top: 17.857rem;
13
- }
14
- }
@@ -1,10 +0,0 @@
1
- export const BEE_LAYOUT_OPTIONS = {
2
- POPUP: "classic-center",
3
- HEADER: "bar-top",
4
- FOOTER: "bar-bottom",
5
- FULLSCREEN: "classic-center",
6
- };
7
- export const MOBILE = "mobile";
8
- export const UNSUBSCRIBE = 'unsubscribe';
9
- export const ANDROID = 'ANDROID';
10
- export const IOS = 'IOS';
@@ -1,194 +0,0 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import PropTypes from 'prop-types';
3
- import { injectIntl } from 'react-intl';
4
- import { connect } from 'react-redux';
5
- // import { bindActionCreators } from 'redux';
6
- import { createStructuredSelector } from 'reselect';
7
- import CapRow from '@capillarytech/cap-ui-library/CapRow';
8
- import { UserIsAuthenticated } from '../../utils/authWrapper';
9
- import TagList from '../TagList';
10
- import {
11
- ANDROID, BEE_LAYOUT_OPTIONS, MOBILE, UNSUBSCRIBE,
12
- } from './constants';
13
- import emptyAndroidSvg from '../../assets/Android.png';
14
- import emptyIosSvg from '../../assets/iOS.png';
15
- import './_beePopupEditor.scss';
16
- function BeePopupEditor(props) {
17
- const {
18
- uid,
19
- id,
20
- tokenData,
21
- saveBeeInstance,
22
- saveBeeData,
23
- saveBeeHtmlValue,
24
- beeJson,
25
- templateLayoutType,
26
- moduleFilterEnabled,
27
- label,
28
- location,
29
- injectedTags,
30
- className,
31
- userLocale,
32
- selectedOfferDetails,
33
- tags,
34
- onContextChange,
35
- device,
36
- } = props;
37
-
38
- let beePluginInstance = null;
39
- let intervalTimer;
40
- const savedCallback = useRef();
41
- const beeInstanceRef = useRef(null);
42
- const isInitializedRef = useRef(false);
43
-
44
- const [visibleTaglist, setVisibleTaglist] = useState(false);
45
- const [selectedTag, setSelectedTag] = useState({});
46
- const filteredTags = (tags || []).filter((obj) => obj.definition.value !== UNSUBSCRIBE);
47
-
48
- useEffect(() => {
49
- // Only recreate BEE editor when layout type changes, not when content (beeJson) changes
50
- // If beeJson is in dependencies, editor reloads on every keystroke!
51
- const beeConfig = {
52
- uid,
53
- trackChanges: true,
54
- container: 'bee-plugin-container',
55
- workspace: {
56
- popup: {
57
- backgroundImageMobile: device === ANDROID ? emptyAndroidSvg : emptyIosSvg,
58
- layout: BEE_LAYOUT_OPTIONS[templateLayoutType],
59
- customStyles: {
60
- container: {
61
- width: "90%",
62
- margin: "1.5rem",
63
- },
64
- },
65
- },
66
- stage: MOBILE,
67
- hideStageToggle: true,
68
- },
69
- contentDialog: {
70
- mergeTags: {
71
- label: 'Add Label',
72
- handler: async (resolve, reject) => {
73
- // this will open tag modal
74
- await setVisibleTaglist(true);
75
- // until tag modal will not open promise will not execute
76
- // once tag modal is opened it will start 2 sec interval to wait use has selected any tag or cancel the tag selection
77
- const promise = new Promise((resolveP) => {
78
- intervalTimer = setInterval(() => {
79
- // this will execute, if user cancel the tag selection
80
- if ((savedCallback.current || {}).close === true) {
81
- reject();
82
- clearInterval(intervalTimer);
83
- return;
84
- }
85
- // this block is checking use has selected any tag or not
86
- if (Object.keys(savedCallback.current || {}).length > 0) {
87
- resolveP(savedCallback.current);
88
- setSelectedTag({});
89
- clearInterval(intervalTimer);
90
- }
91
- }, 2000);
92
- });
93
- // once prmise will resolve , pass the resolve data to handler to show tags in bee edior
94
- const result = await promise;
95
- resolve(result);
96
- },
97
- },
98
- },
99
- onChange: (jsonFile, htmlFile) => {
100
- saveBeeData(jsonFile, htmlFile, device);
101
- },
102
- onSave: (jsonFile, htmlFile) => {
103
- // onSave provides the actual HTML value, use it to update beeHtml.value
104
- if (saveBeeHtmlValue && htmlFile) {
105
- saveBeeHtmlValue(htmlFile, device);
106
- }
107
- // Also call saveBeeData to update JSON
108
- saveBeeData(jsonFile, htmlFile, device);
109
- },
110
- };
111
- window.BeePlugin.create(tokenData, beeConfig, (instance) => {
112
- beePluginInstance = instance;
113
- beeInstanceRef.current = instance;
114
- // Check if beeJson is already an object (happens when layout type changes)
115
- const parseJson = typeof beeJson === 'string' ? JSON.parse(beeJson) : beeJson;
116
- beePluginInstance.start(parseJson);
117
- saveBeeInstance(beePluginInstance, device);
118
- isInitializedRef.current = true;
119
- });
120
- return () => {
121
- clearInterval(intervalTimer);
122
- // Reset initialization flag when component unmounts or layout changes
123
- isInitializedRef.current = false;
124
- };
125
- // IMPORTANT: Only include templateLayoutType, NOT beeJson
126
- // beeJson changes on every keystroke and would cause editor to reload constantly
127
- }, [templateLayoutType]);
128
-
129
- useEffect(() => {
130
- savedCallback.current = Object?.keys(selectedTag)?.length > 0 && selectedTag;
131
- }, [selectedTag]);
132
-
133
- const onTagSelect = (result) => {
134
- const msg = {
135
- name: result,
136
- value: `{{${result}}}`,
137
- };
138
- setSelectedTag(msg);
139
- setVisibleTaglist(false);
140
- };
141
-
142
- const onCancelTagList = () => {
143
- setVisibleTaglist(false);
144
- setSelectedTag({ close: true });
145
- };
146
-
147
- return (
148
- <CapRow>
149
- <div id="bee-plugin-container" className="bee-popup-editor__container"></div>
150
- <TagList
151
- moduleFilterEnabled={moduleFilterEnabled}
152
- label={label}
153
- onTagSelect={onTagSelect}
154
- location={location}
155
- tags={filteredTags}
156
- injectedTags={injectedTags}
157
- className={className}
158
- id={id}
159
- userLocale={userLocale}
160
- selectedOfferDetails={selectedOfferDetails}
161
- visibleTaglist={visibleTaglist}
162
- hidePopover
163
- modalProps={{
164
- onCancel: onCancelTagList,
165
- className: "bee-editor-tag-list bee-editor-tag-list--positioned",
166
- }}
167
- onContextChange={onContextChange}
168
- />
169
- </CapRow>
170
- );
171
- }
172
- BeePopupEditor.propTypes = {
173
- saveBeeData: PropTypes.func.isRequired,
174
- saveBeeInstance: PropTypes.func.isRequired,
175
- beeJson: PropTypes.object.isRequired,
176
- tokenData: PropTypes.object.isRequired,
177
- uid: PropTypes.string.isRequired,
178
- templateLayoutType: PropTypes.string.isRequired,
179
- id: PropTypes.string.isRequired,
180
- moduleFilterEnabled: PropTypes.bool.isRequired,
181
- label: PropTypes.string.isRequired,
182
- location: PropTypes.object.isRequired,
183
- injectedTags: PropTypes.array.isRequired,
184
- className: PropTypes.string.isRequired,
185
- userLocale: PropTypes.string.isRequired,
186
- selectedOfferDetails: PropTypes.object.isRequired,
187
- tags: PropTypes.array.isRequired,
188
- onContextChange: PropTypes.func.isRequired,
189
- device: PropTypes.string.isRequired,
190
- };
191
- const mapStateToProps = () => createStructuredSelector({});
192
-
193
- function mapDispatchToProps() { }
194
- export default UserIsAuthenticated(connect(mapStateToProps, mapDispatchToProps)(injectIntl(BeePopupEditor)));