cap-creatives-ui 8.0.280 → 8.0.321

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 (247) hide show
  1. package/.github/workflows/pr-title-check.yml +88 -0
  2. package/app/constants/unified.js +21 -1
  3. package/app/containers/App/constants.js +0 -1
  4. package/app/containers/Login/test/index.test.js +123 -0
  5. package/app/containers/Login/test/selectors.test.js +165 -0
  6. package/app/initialState.js +0 -2
  7. package/app/services/api.js +6 -0
  8. package/app/services/tests/api.test.js +7 -0
  9. package/app/services/tests/getSchema.test.js +95 -0
  10. package/app/utils/common.js +23 -9
  11. package/app/utils/commonUtils.js +64 -93
  12. package/app/utils/tagValidations.js +83 -219
  13. package/app/utils/templateVarUtils.js +172 -0
  14. package/app/utils/tests/common.test.js +265 -323
  15. package/app/utils/tests/commonUtil.test.js +461 -118
  16. package/app/utils/tests/commonUtils.test.js +581 -0
  17. package/app/utils/tests/messageUtils.test.js +95 -0
  18. package/app/utils/tests/smsCharCount.test.js +304 -0
  19. package/app/utils/tests/smsCharCountV2.test.js +213 -10
  20. package/app/utils/tests/tagValidations.test.js +474 -357
  21. package/app/utils/tests/templateVarUtils.test.js +160 -0
  22. package/app/v2Components/CapDeviceContent/index.js +10 -7
  23. package/app/v2Components/CapTagList/index.js +32 -24
  24. package/app/v2Components/CapTagList/style.scss +48 -0
  25. package/app/v2Components/CapTagListWithInput/__tests__/CapTagListWithInput.test.js +63 -0
  26. package/app/v2Components/CapTagListWithInput/index.js +8 -0
  27. package/app/v2Components/CapWhatsappCTA/index.js +2 -0
  28. package/app/v2Components/CapWhatsappCarouselButton/index.js +32 -14
  29. package/app/v2Components/CapWhatsappCarouselButton/tests/index.test.js +120 -2
  30. package/app/v2Components/CommonTestAndPreview/CustomValuesEditor.js +70 -49
  31. package/app/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +39 -0
  32. package/app/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +606 -0
  33. package/app/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.scss +36 -0
  34. package/app/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +79 -0
  35. package/app/v2Components/CommonTestAndPreview/DeliverySettings/index.js +314 -0
  36. package/app/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +141 -0
  37. package/app/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +156 -0
  38. package/app/v2Components/CommonTestAndPreview/SendTestMessage.js +57 -1
  39. package/app/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +20 -1
  40. package/app/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +133 -4
  41. package/app/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +210 -4
  42. package/app/v2Components/CommonTestAndPreview/actions.js +20 -0
  43. package/app/v2Components/CommonTestAndPreview/constants.js +57 -1
  44. package/app/v2Components/CommonTestAndPreview/index.js +878 -156
  45. package/app/v2Components/CommonTestAndPreview/messages.js +41 -3
  46. package/app/v2Components/CommonTestAndPreview/previewApiUtils.js +59 -0
  47. package/app/v2Components/CommonTestAndPreview/reducer.js +47 -0
  48. package/app/v2Components/CommonTestAndPreview/sagas.js +75 -5
  49. package/app/v2Components/CommonTestAndPreview/selectors.js +51 -0
  50. package/app/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +352 -0
  51. package/app/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +1156 -0
  52. package/app/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +334 -0
  53. package/app/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +576 -0
  54. package/app/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +156 -0
  55. package/app/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +199 -1
  56. package/app/v2Components/CommonTestAndPreview/tests/actions.test.js +50 -0
  57. package/app/v2Components/CommonTestAndPreview/tests/constants.test.js +18 -7
  58. package/app/v2Components/CommonTestAndPreview/tests/index.test.js +914 -5
  59. package/app/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +67 -0
  60. package/app/v2Components/CommonTestAndPreview/tests/reducer.test.js +118 -0
  61. package/app/v2Components/CommonTestAndPreview/tests/sagas.test.js +146 -378
  62. package/app/v2Components/CommonTestAndPreview/tests/selectors.test.js +146 -0
  63. package/app/v2Components/ErrorInfoNote/index.js +24 -26
  64. package/app/v2Components/FormBuilder/index.js +182 -204
  65. package/app/v2Components/FormBuilder/messages.js +4 -8
  66. package/app/v2Components/HtmlEditor/HTMLEditor.js +7 -6
  67. package/app/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +1 -1
  68. package/app/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +928 -17
  69. package/app/v2Components/HtmlEditor/components/CodeEditorPane/index.js +4 -2
  70. package/app/v2Components/HtmlEditor/hooks/__tests__/useValidation.test.js +452 -3
  71. package/app/v2Components/HtmlEditor/hooks/useValidation.js +12 -9
  72. package/app/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +132 -0
  73. package/app/v2Components/HtmlEditor/utils/htmlValidator.js +4 -2
  74. package/app/v2Components/SmsFallback/SmsFallbackLocalSelector.js +87 -0
  75. package/app/v2Components/SmsFallback/constants.js +73 -0
  76. package/app/v2Components/SmsFallback/index.js +956 -0
  77. package/app/v2Components/SmsFallback/index.scss +265 -0
  78. package/app/v2Components/SmsFallback/messages.js +78 -0
  79. package/app/v2Components/SmsFallback/smsFallbackUtils.js +107 -0
  80. package/app/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +50 -0
  81. package/app/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +147 -0
  82. package/app/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +304 -0
  83. package/app/v2Components/SmsFallback/tests/smsFallbackUi.test.js +197 -0
  84. package/app/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +261 -0
  85. package/app/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +422 -0
  86. package/app/v2Components/SmsFallback/useLocalTemplateList.js +92 -0
  87. package/app/v2Components/TestAndPreviewSlidebox/index.js +22 -1
  88. package/app/v2Components/TestAndPreviewSlidebox/sagas.js +11 -4
  89. package/app/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +3 -1
  90. package/app/v2Components/VarSegmentMessageEditor/constants.js +2 -0
  91. package/app/v2Components/VarSegmentMessageEditor/index.js +125 -0
  92. package/app/v2Components/VarSegmentMessageEditor/index.scss +46 -0
  93. package/app/v2Containers/BeeEditor/index.js +3 -0
  94. package/app/v2Containers/BeePopupEditor/index.js +9 -2
  95. package/app/v2Containers/Cap/mockData.js +0 -14
  96. package/app/v2Containers/Cap/reducer.js +3 -55
  97. package/app/v2Containers/Cap/tests/reducer.test.js +0 -102
  98. package/app/v2Containers/CommunicationFlow/CommunicationFlow.js +291 -0
  99. package/app/v2Containers/CommunicationFlow/CommunicationFlow.scss +25 -0
  100. package/app/v2Containers/CommunicationFlow/Tests/CommunicationFlow.test.js +255 -0
  101. package/app/v2Containers/CommunicationFlow/constants.js +200 -0
  102. package/app/v2Containers/CommunicationFlow/index.js +102 -0
  103. package/app/v2Containers/CommunicationFlow/messages.js +346 -0
  104. package/app/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/ChannelSelectionStep.js +522 -0
  105. package/app/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/ChannelSelectionStep.scss +170 -0
  106. package/app/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/Tests/ChannelSelectionStep.test.js +796 -0
  107. package/app/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/index.js +5 -0
  108. package/app/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/CommunicationStrategyStep.js +95 -0
  109. package/app/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/Tests/CommunicationStrategyStep.test.js +133 -0
  110. package/app/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/index.js +5 -0
  111. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/DeliverySettingsSection.js +289 -0
  112. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/DeliverySettingsSection.scss +70 -0
  113. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/SenderDetails.js +319 -0
  114. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/SenderDetails.scss +69 -0
  115. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/DeliverySettingsSection.test.js +616 -0
  116. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/SenderDetails.test.js +577 -0
  117. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/deliverySettingsConfig.test.js +1111 -0
  118. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/deliverySettingsConfig.js +696 -0
  119. package/app/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/index.js +7 -0
  120. package/app/v2Containers/CommunicationFlow/steps/DynamicControlsStep/DynamicControlsStep.js +102 -0
  121. package/app/v2Containers/CommunicationFlow/steps/DynamicControlsStep/DynamicControlsStep.scss +36 -0
  122. package/app/v2Containers/CommunicationFlow/steps/DynamicControlsStep/Tests/DynamicControlsStep.test.js +91 -0
  123. package/app/v2Containers/CommunicationFlow/steps/DynamicControlsStep/index.js +5 -0
  124. package/app/v2Containers/CommunicationFlow/steps/MessageTypeStep/MessageTypeStep.js +86 -0
  125. package/app/v2Containers/CommunicationFlow/steps/MessageTypeStep/Tests/MessageTypeStep.test.js +100 -0
  126. package/app/v2Containers/CommunicationFlow/steps/MessageTypeStep/index.js +5 -0
  127. package/app/v2Containers/CommunicationFlow/utils/getEnabledSteps.js +30 -0
  128. package/app/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +43 -0
  129. package/app/v2Containers/CreativesContainer/SlideBoxContent.js +127 -11
  130. package/app/v2Containers/CreativesContainer/SlideBoxFooter.js +62 -9
  131. package/app/v2Containers/CreativesContainer/SlideBoxHeader.js +29 -4
  132. package/app/v2Containers/CreativesContainer/constants.js +24 -0
  133. package/app/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +67 -0
  134. package/app/v2Containers/CreativesContainer/index.js +346 -71
  135. package/app/v2Containers/CreativesContainer/index.scss +51 -1
  136. package/app/v2Containers/CreativesContainer/messages.js +12 -0
  137. package/app/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +90 -0
  138. package/app/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +69 -1
  139. package/app/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +443 -0
  140. package/app/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +110 -0
  141. package/app/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +147 -4
  142. package/app/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +363 -0
  143. package/app/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +57 -10
  144. package/app/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +258 -0
  145. package/app/v2Containers/CreativesContainer/tests/index.test.js +71 -9
  146. package/app/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +125 -0
  147. package/app/v2Containers/Email/index.js +2 -5
  148. package/app/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +58 -77
  149. package/app/v2Containers/EmailWrapper/components/EmailWrapperView.js +3 -0
  150. package/app/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +158 -89
  151. package/app/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +16 -1
  152. package/app/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +17 -12
  153. package/app/v2Containers/EmailWrapper/index.js +4 -0
  154. package/app/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +1 -0
  155. package/app/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +133 -0
  156. package/app/v2Containers/FTP/index.js +2 -51
  157. package/app/v2Containers/FTP/messages.js +0 -4
  158. package/app/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +110 -155
  159. package/app/v2Containers/InApp/index.js +297 -118
  160. package/app/v2Containers/InApp/tests/index.test.js +17 -6
  161. package/app/v2Containers/InApp/tests/mockData.js +1 -1
  162. package/app/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +19 -0
  163. package/app/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +3 -0
  164. package/app/v2Containers/InAppWrapper/index.js +3 -0
  165. package/app/v2Containers/InappAdvance/index.js +5 -104
  166. package/app/v2Containers/InappAdvance/tests/index.test.js +2 -0
  167. package/app/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +24 -3
  168. package/app/v2Containers/Line/Container/Text/index.js +0 -1
  169. package/app/v2Containers/MobilePush/Create/index.js +105 -28
  170. package/app/v2Containers/MobilePush/Create/messages.js +4 -0
  171. package/app/v2Containers/MobilePush/Edit/index.js +250 -68
  172. package/app/v2Containers/MobilePush/Edit/messages.js +4 -0
  173. package/app/v2Containers/MobilePushNew/components/PlatformContentFields.js +36 -12
  174. package/app/v2Containers/MobilePushNew/components/tests/PlatformContentFields.test.js +68 -27
  175. package/app/v2Containers/MobilePushNew/index.js +78 -35
  176. package/app/v2Containers/MobilePushNew/messages.js +8 -0
  177. package/app/v2Containers/MobilepushWrapper/index.js +11 -1
  178. package/app/v2Containers/Rcs/constants.js +32 -1
  179. package/app/v2Containers/Rcs/index.js +963 -916
  180. package/app/v2Containers/Rcs/index.scss +85 -6
  181. package/app/v2Containers/Rcs/messages.js +10 -1
  182. package/app/v2Containers/Rcs/rcsLibraryHydrationUtils.js +205 -0
  183. package/app/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +41136 -1566
  184. package/app/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +0 -5
  185. package/app/v2Containers/Rcs/tests/index.test.js +41 -38
  186. package/app/v2Containers/Rcs/tests/mockData.js +38 -0
  187. package/app/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +251 -0
  188. package/app/v2Containers/Rcs/tests/utils.test.js +379 -1
  189. package/app/v2Containers/Rcs/utils.js +358 -10
  190. package/app/v2Containers/Sms/Create/index.js +122 -39
  191. package/app/v2Containers/Sms/Create/messages.js +4 -0
  192. package/app/v2Containers/Sms/Edit/index.js +37 -3
  193. package/app/v2Containers/Sms/commonMethods.js +3 -6
  194. package/app/v2Containers/Sms/smsFormDataHelpers.js +67 -0
  195. package/app/v2Containers/Sms/tests/commonMethods.test.js +122 -0
  196. package/app/v2Containers/Sms/tests/smsFormDataHelpers.test.js +253 -0
  197. package/app/v2Containers/SmsTrai/Create/index.js +9 -4
  198. package/app/v2Containers/SmsTrai/Create/index.scss +1 -1
  199. package/app/v2Containers/SmsTrai/Edit/constants.js +2 -0
  200. package/app/v2Containers/SmsTrai/Edit/index.js +667 -160
  201. package/app/v2Containers/SmsTrai/Edit/index.scss +121 -0
  202. package/app/v2Containers/SmsTrai/Edit/messages.js +9 -4
  203. package/app/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4590 -2436
  204. package/app/v2Containers/SmsWrapper/index.js +41 -8
  205. package/app/v2Containers/TagList/index.js +63 -2
  206. package/app/v2Containers/TagList/messages.js +8 -0
  207. package/app/v2Containers/TagList/tests/TagList.test.js +122 -20
  208. package/app/v2Containers/TagList/tests/mockdata.js +17 -0
  209. package/app/v2Containers/Templates/TemplatesActionBar.js +101 -0
  210. package/app/v2Containers/Templates/_templates.scss +61 -2
  211. package/app/v2Containers/Templates/actions.js +11 -0
  212. package/app/v2Containers/Templates/constants.js +2 -0
  213. package/app/v2Containers/Templates/index.js +90 -40
  214. package/app/v2Containers/Templates/reducer.js +3 -1
  215. package/app/v2Containers/Templates/sagas.js +57 -12
  216. package/app/v2Containers/Templates/tests/TemplatesActionBar.test.js +120 -0
  217. package/app/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1043 -1079
  218. package/app/v2Containers/Templates/tests/reducer.test.js +12 -0
  219. package/app/v2Containers/Templates/tests/sagas.test.js +193 -12
  220. package/app/v2Containers/Templates/tests/smsTemplatesListApi.test.js +180 -0
  221. package/app/v2Containers/Templates/utils/smsTemplatesListApi.js +79 -0
  222. package/app/v2Containers/TemplatesV2/TemplatesV2.style.js +72 -1
  223. package/app/v2Containers/TemplatesV2/index.js +147 -49
  224. package/app/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +131 -0
  225. package/app/v2Containers/Viber/index.js +9 -10
  226. package/app/v2Containers/Viber/index.scss +1 -1
  227. package/app/v2Containers/WebPush/Create/components/BrandIconSection.test.js +264 -0
  228. package/app/v2Containers/WebPush/Create/components/MessageSection.js +78 -19
  229. package/app/v2Containers/WebPush/Create/components/MessageSection.test.js +82 -0
  230. package/app/v2Containers/WebPush/Create/components/__snapshots__/BrandIconSection.test.js.snap +187 -0
  231. package/app/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +25 -17
  232. package/app/v2Containers/WebPush/Create/hooks/useAiraTriggerPosition.js +80 -0
  233. package/app/v2Containers/WebPush/Create/hooks/useAiraTriggerPosition.test.js +210 -0
  234. package/app/v2Containers/WebPush/Create/hooks/useTagManagement.js +1 -5
  235. package/app/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +0 -7
  236. package/app/v2Containers/WebPush/Create/index.js +36 -6
  237. package/app/v2Containers/WebPush/Create/index.scss +5 -0
  238. package/app/v2Containers/WebPush/Create/messages.js +8 -1
  239. package/app/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +269 -0
  240. package/app/v2Containers/WebPush/Create/utils/validation.js +31 -15
  241. package/app/v2Containers/WebPush/Create/utils/validation.test.js +72 -24
  242. package/app/v2Containers/Whatsapp/index.js +28 -53
  243. package/app/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +26939 -3982
  244. package/app/v2Containers/Whatsapp/tests/index.test.js +172 -0
  245. package/app/v2Containers/Zalo/index.js +5 -11
  246. package/package.json +2 -2
  247. package/version +9 -0
@@ -0,0 +1,187 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`BrandIconSection snapshot matches snapshot for DONT_SHOW state 1`] = `
4
+ <Fragment>
5
+ <CapRow
6
+ className="creatives-webpush-brand-icon"
7
+ >
8
+ <CapHeading
9
+ className="webpush-brand-icon"
10
+ type="h4"
11
+ >
12
+ <FormattedMessage
13
+ defaultMessage="Brand Icon/Logo"
14
+ id="app.webpush.brandIconLogo"
15
+ values={Object {}}
16
+ />
17
+ </CapHeading>
18
+ <CapRadioGroup
19
+ disabled={false}
20
+ errorMessage=""
21
+ onChange={[MockFunction]}
22
+ options={
23
+ Array [
24
+ Object {
25
+ "label": undefined,
26
+ "value": "DONT_SHOW",
27
+ },
28
+ Object {
29
+ "label": undefined,
30
+ "value": "UPLOAD_IMAGE",
31
+ },
32
+ ]
33
+ }
34
+ value="DONT_SHOW"
35
+ />
36
+ </CapRow>
37
+ <CapDivider />
38
+ </Fragment>
39
+ `;
40
+
41
+ exports[`BrandIconSection snapshot matches snapshot for UPLOAD_IMAGE state 1`] = `
42
+ <Fragment>
43
+ <CapRow
44
+ className="creatives-webpush-brand-icon"
45
+ >
46
+ <CapHeading
47
+ className="webpush-brand-icon"
48
+ type="h4"
49
+ >
50
+ <FormattedMessage
51
+ defaultMessage="Brand Icon/Logo"
52
+ id="app.webpush.brandIconLogo"
53
+ values={Object {}}
54
+ />
55
+ </CapHeading>
56
+ <CapRadioGroup
57
+ disabled={false}
58
+ errorMessage=""
59
+ onChange={[MockFunction]}
60
+ options={
61
+ Array [
62
+ Object {
63
+ "label": undefined,
64
+ "value": "DONT_SHOW",
65
+ },
66
+ Object {
67
+ "label": undefined,
68
+ "value": "UPLOAD_IMAGE",
69
+ },
70
+ ]
71
+ }
72
+ value="UPLOAD_IMAGE"
73
+ />
74
+ </CapRow>
75
+ <CapRow
76
+ aria-disabled={false}
77
+ className="webpush-brand-icon-upload-section"
78
+ >
79
+ <InjectIntl(CapImageUpload)
80
+ allowedExtensionsRegex={/\\\\\\.\\(jpe\\?g\\|png\\)\\$/i}
81
+ channel="WEBPUSH_BRAND_ICON"
82
+ className="cap-custom-image-upload"
83
+ disabled={false}
84
+ imageData={Object {}}
85
+ imageSrc=""
86
+ imgSize={1000000}
87
+ index={1}
88
+ isFullMode={true}
89
+ key="webpush-brand-icon-uploaded-image"
90
+ recommendedDimensions={
91
+ Array [
92
+ Object {
93
+ "height": 192,
94
+ "width": 192,
95
+ },
96
+ Object {
97
+ "height": 256,
98
+ "width": 256,
99
+ },
100
+ ]
101
+ }
102
+ showReUploadButton={true}
103
+ updateImageSrc={[MockFunction]}
104
+ updateOnReUpload={[MockFunction]}
105
+ uploadAsset={[MockFunction]}
106
+ />
107
+ </CapRow>
108
+ <CapDivider />
109
+ </Fragment>
110
+ `;
111
+
112
+ exports[`BrandIconSection snapshot matches snapshot for locked UPLOAD_IMAGE state 1`] = `
113
+ <Fragment>
114
+ <CapRow
115
+ className="creatives-webpush-brand-icon"
116
+ >
117
+ <CapHeading
118
+ className="webpush-brand-icon"
119
+ type="h4"
120
+ >
121
+ <FormattedMessage
122
+ defaultMessage="Brand Icon/Logo"
123
+ id="app.webpush.brandIconLogo"
124
+ values={Object {}}
125
+ />
126
+ </CapHeading>
127
+ <CapRadioGroup
128
+ disabled={false}
129
+ errorMessage=""
130
+ onChange={[MockFunction]}
131
+ options={
132
+ Array [
133
+ Object {
134
+ "label": undefined,
135
+ "value": "DONT_SHOW",
136
+ },
137
+ Object {
138
+ "label": undefined,
139
+ "value": "UPLOAD_IMAGE",
140
+ },
141
+ ]
142
+ }
143
+ value="UPLOAD_IMAGE"
144
+ />
145
+ </CapRow>
146
+ <CapRow
147
+ aria-disabled={true}
148
+ className="webpush-brand-icon-upload-section"
149
+ style={
150
+ Object {
151
+ "opacity": 0.5,
152
+ "pointerEvents": "none",
153
+ }
154
+ }
155
+ >
156
+ <InjectIntl(CapImageUpload)
157
+ allowedExtensionsRegex={/\\\\\\.\\(jpe\\?g\\|png\\)\\$/i}
158
+ channel="WEBPUSH_BRAND_ICON"
159
+ className="cap-custom-image-upload"
160
+ disabled={true}
161
+ imageData={Object {}}
162
+ imageSrc=""
163
+ imgSize={1000000}
164
+ index={1}
165
+ isFullMode={true}
166
+ key="webpush-brand-icon-uploaded-image"
167
+ recommendedDimensions={
168
+ Array [
169
+ Object {
170
+ "height": 192,
171
+ "width": 192,
172
+ },
173
+ Object {
174
+ "height": 256,
175
+ "width": 256,
176
+ },
177
+ ]
178
+ }
179
+ showReUploadButton={true}
180
+ updateImageSrc={[MockFunction]}
181
+ updateOnReUpload={[MockFunction]}
182
+ uploadAsset={[MockFunction]}
183
+ />
184
+ </CapRow>
185
+ <CapDivider />
186
+ </Fragment>
187
+ `;
@@ -18,28 +18,36 @@ exports[`MessageSection Rendering should render correctly with default props 1`]
18
18
  values={Object {}}
19
19
  />
20
20
  </CapHeading>
21
- <InjectIntl(Wrapper)
21
+ <InputWrapper
22
+ error=""
23
+ inputRef={null}
24
+ isAiContentBotDisabled={true}
22
25
  onChange={[MockFunction]}
23
- textAreaRef={null}
24
26
  value="Test Message"
25
27
  >
26
- <_Class
27
- autosize={
28
- Object {
29
- "maxRows": 5,
30
- "minRows": 3,
31
- }
32
- }
33
- errorMessage=""
34
- id="webpush-message-input"
35
- isRequired={true}
36
- labelPosition="top"
28
+ <InjectIntl(Wrapper)
37
29
  onChange={[MockFunction]}
38
- setInputRef={[MockFunction]}
39
- size="default"
30
+ textAreaRef={null}
40
31
  value="Test Message"
41
- />
42
- </InjectIntl(Wrapper)>
32
+ >
33
+ <_Class
34
+ autosize={
35
+ Object {
36
+ "maxRows": 5,
37
+ "minRows": 3,
38
+ }
39
+ }
40
+ errorMessage=""
41
+ id="webpush-message-input"
42
+ isRequired={true}
43
+ labelPosition="top"
44
+ onChange={[MockFunction]}
45
+ setInputRef={[MockFunction]}
46
+ size="default"
47
+ value="Test Message"
48
+ />
49
+ </InjectIntl(Wrapper)>
50
+ </InputWrapper>
43
51
  <CapLabel
44
52
  className="webpush-character-count"
45
53
  type="label2"
@@ -0,0 +1,80 @@
1
+ import { useLayoutEffect, useMemo, useState } from 'react';
2
+
3
+ const DEFAULT_BOTTOM = '0.83rem';
4
+
5
+ export const getBottomOffset = (wrapperElement, inputElement, hasError) => {
6
+ if (!wrapperElement || !inputElement) {
7
+ return DEFAULT_BOTTOM;
8
+ }
9
+
10
+ if (!hasError) {
11
+ return DEFAULT_BOTTOM;
12
+ }
13
+
14
+ const inputRect = inputElement.getBoundingClientRect();
15
+ const wrapperRect = wrapperElement.getBoundingClientRect();
16
+ const inputBottomFromWrapperTop = inputRect.bottom - wrapperRect.top;
17
+ const distanceFromWrapperBottom = wrapperRect.height - inputBottomFromWrapperTop;
18
+
19
+ return `${Math.max(distanceFromWrapperBottom + 4, 4)}px`;
20
+ };
21
+
22
+ export const useAiraTriggerPosition = ({
23
+ wrapperRef,
24
+ inputRef,
25
+ rightOffset = '2.5rem',
26
+ error,
27
+ }) => {
28
+ const [bottomOffset, setBottomOffset] = useState(DEFAULT_BOTTOM);
29
+
30
+ useLayoutEffect(() => {
31
+ const wrapperElement = wrapperRef?.current;
32
+ if (!wrapperElement) {
33
+ setBottomOffset(DEFAULT_BOTTOM);
34
+ return undefined;
35
+ }
36
+
37
+ const updatePosition = () => {
38
+ const inputElement = inputRef?.current;
39
+ const hasError = Boolean(
40
+ error
41
+ || wrapperElement.querySelector('.error-message')
42
+ || wrapperElement.querySelector('.webpush-template-message-error'),
43
+ );
44
+ const nextOffset = getBottomOffset(wrapperElement, inputElement, hasError);
45
+ setBottomOffset((prevOffset) => (
46
+ prevOffset === nextOffset ? prevOffset : nextOffset
47
+ ));
48
+ };
49
+
50
+ updatePosition();
51
+
52
+ let resizeObserver = null;
53
+
54
+ if (window.ResizeObserver) {
55
+ resizeObserver = new window.ResizeObserver(() => {
56
+ updatePosition();
57
+ });
58
+ resizeObserver.observe(wrapperElement);
59
+ if (inputRef?.current) {
60
+ resizeObserver.observe(inputRef.current);
61
+ }
62
+ }
63
+
64
+ return () => {
65
+ if (resizeObserver) {
66
+ resizeObserver.disconnect();
67
+ }
68
+ };
69
+ }, [wrapperRef, inputRef, error]);
70
+
71
+ return useMemo(
72
+ () => ({
73
+ bottom: bottomOffset,
74
+ right: rightOffset,
75
+ left: 'auto',
76
+ }),
77
+ [bottomOffset, rightOffset],
78
+ );
79
+ };
80
+
@@ -0,0 +1,210 @@
1
+ import { renderHook } from '@testing-library/react';
2
+ import { getBottomOffset, useAiraTriggerPosition } from './useAiraTriggerPosition';
3
+
4
+ describe('useAiraTriggerPosition', () => {
5
+ let resizeObserverCallback;
6
+ let observeMock;
7
+ let disconnectMock;
8
+
9
+ beforeEach(() => {
10
+ observeMock = jest.fn();
11
+ disconnectMock = jest.fn();
12
+ resizeObserverCallback = null;
13
+
14
+ global.ResizeObserver = jest.fn((cb) => {
15
+ resizeObserverCallback = cb;
16
+ return {
17
+ observe: observeMock,
18
+ disconnect: disconnectMock,
19
+ };
20
+ });
21
+ });
22
+
23
+ afterEach(() => {
24
+ jest.clearAllMocks();
25
+ global.ResizeObserver = jest.fn((cb) => {
26
+ resizeObserverCallback = cb;
27
+ return {
28
+ observe: observeMock,
29
+ disconnect: disconnectMock,
30
+ };
31
+ });
32
+ });
33
+
34
+ const createRefs = () => {
35
+ const wrapperElement = document.createElement('div');
36
+ const inputElement = document.createElement('textarea');
37
+ wrapperElement.appendChild(inputElement);
38
+
39
+ const wrapperRef = { current: wrapperElement };
40
+ const inputRef = { current: inputElement };
41
+
42
+ return { wrapperElement, inputElement, wrapperRef, inputRef };
43
+ };
44
+
45
+ it('should return default style when there is no error', () => {
46
+ const { wrapperRef, inputRef } = createRefs();
47
+
48
+ const { result } = renderHook(() => useAiraTriggerPosition({
49
+ wrapperRef,
50
+ inputRef,
51
+ rightOffset: '2.5rem',
52
+ value: 'hello',
53
+ error: '',
54
+ }));
55
+
56
+ expect(result.current).toEqual({
57
+ bottom: '0.83rem',
58
+ right: '2.5rem',
59
+ left: 'auto',
60
+ });
61
+ });
62
+
63
+ it('should compute bottom offset when error is present', () => {
64
+ const { wrapperElement, inputElement, wrapperRef, inputRef } = createRefs();
65
+
66
+ const errorElement = document.createElement('div');
67
+ errorElement.className = 'webpush-template-message-error';
68
+ wrapperElement.appendChild(errorElement);
69
+
70
+ wrapperElement.getBoundingClientRect = jest.fn(() => ({
71
+ top: 0,
72
+ bottom: 160,
73
+ height: 160,
74
+ left: 0,
75
+ right: 100,
76
+ width: 100,
77
+ }));
78
+ inputElement.getBoundingClientRect = jest.fn(() => ({
79
+ top: 20,
80
+ bottom: 100,
81
+ height: 80,
82
+ left: 0,
83
+ right: 100,
84
+ width: 100,
85
+ }));
86
+
87
+ const { result } = renderHook(() => useAiraTriggerPosition({
88
+ wrapperRef,
89
+ inputRef,
90
+ rightOffset: '2.5rem',
91
+ value: 'hello',
92
+ error: 'Required',
93
+ }));
94
+
95
+ expect(result.current).toEqual({
96
+ bottom: '64px',
97
+ right: '2.5rem',
98
+ left: 'auto',
99
+ });
100
+ });
101
+
102
+ it('should observe wrapper and input for layout changes', () => {
103
+ const { wrapperElement, inputElement, wrapperRef, inputRef } = createRefs();
104
+
105
+ renderHook(() => useAiraTriggerPosition({
106
+ wrapperRef,
107
+ inputRef,
108
+ rightOffset: '2.5rem',
109
+ value: '',
110
+ error: '',
111
+ }));
112
+
113
+ expect(observeMock).toHaveBeenCalledWith(wrapperElement);
114
+ expect(observeMock).toHaveBeenCalledWith(inputElement);
115
+ expect(typeof resizeObserverCallback).toBe('function');
116
+ });
117
+
118
+ it('should invoke updatePosition when ResizeObserver fires', () => {
119
+ const { wrapperElement, inputElement, wrapperRef, inputRef } = createRefs();
120
+
121
+ renderHook(() => useAiraTriggerPosition({
122
+ wrapperRef,
123
+ inputRef,
124
+ rightOffset: '2.5rem',
125
+ error: '',
126
+ }));
127
+
128
+ expect(resizeObserverCallback).toBeTruthy();
129
+ resizeObserverCallback();
130
+ expect(observeMock).toHaveBeenCalledWith(wrapperElement);
131
+ expect(observeMock).toHaveBeenCalledWith(inputElement);
132
+ });
133
+
134
+ it('should not observe input when inputRef has no current element', () => {
135
+ const { wrapperElement, wrapperRef } = createRefs();
136
+
137
+ renderHook(() => useAiraTriggerPosition({
138
+ wrapperRef,
139
+ inputRef: { current: null },
140
+ rightOffset: '2.5rem',
141
+ error: '',
142
+ }));
143
+
144
+ expect(observeMock).toHaveBeenCalledWith(wrapperElement);
145
+ expect(observeMock).toHaveBeenCalledTimes(1);
146
+ });
147
+
148
+ it('should use default right offset when omitted', () => {
149
+ const { wrapperRef, inputRef } = createRefs();
150
+
151
+ const { result } = renderHook(() => useAiraTriggerPosition({
152
+ wrapperRef,
153
+ inputRef,
154
+ error: '',
155
+ }));
156
+
157
+ expect(result.current.right).toBe('2.5rem');
158
+ });
159
+
160
+ it('should use default bottom when wrapper ref is not attached', () => {
161
+ const wrapperRef = { current: null };
162
+ const inputRef = { current: null };
163
+
164
+ const { result } = renderHook(() => useAiraTriggerPosition({
165
+ wrapperRef,
166
+ inputRef,
167
+ rightOffset: '2.5rem',
168
+ error: '',
169
+ }));
170
+
171
+ expect(result.current).toEqual({
172
+ bottom: '0.83rem',
173
+ right: '2.5rem',
174
+ left: 'auto',
175
+ });
176
+ });
177
+
178
+ it('should skip disconnect when ResizeObserver is unavailable', () => {
179
+ const saved = global.ResizeObserver;
180
+ delete global.ResizeObserver;
181
+
182
+ const { wrapperRef, inputRef } = createRefs();
183
+
184
+ const { unmount } = renderHook(() => useAiraTriggerPosition({
185
+ wrapperRef,
186
+ inputRef,
187
+ rightOffset: '2.5rem',
188
+ error: '',
189
+ }));
190
+
191
+ expect(disconnectMock).not.toHaveBeenCalled();
192
+ unmount();
193
+ expect(disconnectMock).not.toHaveBeenCalled();
194
+
195
+ global.ResizeObserver = saved;
196
+ });
197
+ });
198
+
199
+ describe('getBottomOffset', () => {
200
+ it('returns default when wrapper element is missing', () => {
201
+ const input = document.createElement('textarea');
202
+ expect(getBottomOffset(null, input, true)).toBe('0.83rem');
203
+ });
204
+
205
+ it('returns default when input element is missing', () => {
206
+ const wrapper = document.createElement('div');
207
+ expect(getBottomOffset(wrapper, null, true)).toBe('0.83rem');
208
+ });
209
+ });
210
+
@@ -22,8 +22,6 @@ export const useTagManagement = ({
22
22
  metaEntities,
23
23
  getDefaultTags,
24
24
  supportedTags = EMPTY_ARRAY,
25
- injectedTags,
26
- eventContextTags = EMPTY_ARRAY,
27
25
  }) => {
28
26
  const [tags, setTags] = useState([]);
29
27
  const tagFetchKeyRef = useRef(null);
@@ -105,12 +103,10 @@ export const useTagManagement = ({
105
103
  const validationConfig = useMemo(
106
104
  () => ({
107
105
  tagsParam: tags,
108
- injectedTagsParams: injectedTags,
109
106
  location,
110
107
  tagModule: getDefaultTags,
111
- eventContextTags,
112
108
  }),
113
- [tags, injectedTags, location, getDefaultTags, eventContextTags],
109
+ [tags, location, getDefaultTags],
114
110
  );
115
111
 
116
112
  return {
@@ -528,26 +528,19 @@ describe('useTagManagement', () => {
528
528
 
529
529
  describe('validationConfig', () => {
530
530
  it('should return validation config with tags', () => {
531
- const injectedTags = [{ id: 5, name: 'Injected Tag' }];
532
- const eventContextTags = [{ id: 6, name: 'Event Tag' }];
533
-
534
531
  const { result } = renderHook(() =>
535
532
  useTagManagement({
536
533
  location: defaultLocation,
537
534
  globalActions: mockGlobalActions,
538
535
  metaEntities: defaultMetaEntities,
539
- injectedTags,
540
- eventContextTags,
541
536
  getDefaultTags: 'custom',
542
537
  })
543
538
  );
544
539
 
545
540
  expect(result.current.validationConfig).toEqual({
546
541
  tagsParam: defaultMetaEntities.tags.standard,
547
- injectedTagsParams: injectedTags,
548
542
  location: defaultLocation,
549
543
  tagModule: 'custom',
550
- eventContextTags,
551
544
  });
552
545
  });
553
546