@capillarytech/creatives-library 8.0.262 → 8.0.264

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 (162) hide show
  1. package/assets/Android.png +0 -0
  2. package/assets/iOS.png +0 -0
  3. package/constants/unified.js +1 -2
  4. package/initialReducer.js +0 -2
  5. package/package.json +1 -1
  6. package/services/api.js +0 -10
  7. package/services/tests/api.test.js +0 -34
  8. package/tests/integration/TemplateCreation/TemplateCreation.integration.test.js +35 -17
  9. package/tests/integration/TemplateCreation/api-response.js +1 -31
  10. package/tests/integration/TemplateCreation/msw-handler.js +0 -2
  11. package/utils/common.js +0 -5
  12. package/utils/commonUtils.js +5 -28
  13. package/utils/tagValidations.js +2 -1
  14. package/utils/tests/commonUtil.test.js +0 -224
  15. package/utils/transformTemplateConfig.js +10 -0
  16. package/v2Components/CapDeviceContent/index.js +56 -61
  17. package/v2Components/CapTagList/index.js +1 -6
  18. package/v2Components/CapTagListWithInput/index.js +1 -5
  19. package/v2Components/CapTagListWithInput/messages.js +1 -1
  20. package/v2Components/CapWhatsappCTA/tests/index.test.js +0 -5
  21. package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +2 -2
  22. package/v2Components/ErrorInfoNote/index.js +72 -402
  23. package/v2Components/ErrorInfoNote/messages.js +6 -32
  24. package/v2Components/ErrorInfoNote/style.scss +6 -278
  25. package/v2Components/FormBuilder/index.js +8 -8
  26. package/v2Components/FormBuilder/tests/index.test.js +4 -13
  27. package/v2Components/HtmlEditor/HTMLEditor.js +99 -416
  28. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +133 -1882
  29. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +16 -27
  30. package/v2Components/HtmlEditor/_htmlEditor.scss +45 -108
  31. package/v2Components/HtmlEditor/_index.lazy.scss +1 -0
  32. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +102 -23
  33. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +140 -148
  34. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +1 -2
  35. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  36. package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +0 -9
  37. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +4 -4
  38. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -22
  39. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
  40. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
  41. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
  42. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
  44. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +10 -7
  45. package/v2Components/HtmlEditor/components/PreviewPane/index.js +43 -22
  46. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  47. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +152 -0
  48. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/_validationErrorDisplay.scss +0 -18
  49. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -36
  50. package/v2Components/HtmlEditor/components/ValidationPanel/_validationPanel.scss +34 -46
  51. package/v2Components/HtmlEditor/components/ValidationPanel/index.js +46 -51
  52. package/v2Components/HtmlEditor/constants.js +20 -42
  53. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +16 -373
  54. package/v2Components/HtmlEditor/hooks/__tests__/useValidation.test.js +16 -351
  55. package/v2Components/HtmlEditor/hooks/useEditorContent.js +2 -5
  56. package/v2Components/HtmlEditor/hooks/useInAppContent.js +146 -88
  57. package/v2Components/HtmlEditor/hooks/useValidation.js +55 -211
  58. package/v2Components/HtmlEditor/index.js +1 -1
  59. package/v2Components/HtmlEditor/messages.js +94 -92
  60. package/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +45 -214
  61. package/v2Components/HtmlEditor/utils/__tests__/validationAdapter.test.js +0 -134
  62. package/v2Components/HtmlEditor/utils/contentSanitizer.js +41 -40
  63. package/v2Components/HtmlEditor/utils/htmlValidator.js +72 -71
  64. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +102 -134
  65. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
  66. package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -66
  67. package/v2Components/MobilePushPreviewV2/index.js +7 -32
  68. package/v2Components/TemplatePreview/_templatePreview.scss +24 -55
  69. package/v2Components/TemplatePreview/index.js +32 -47
  70. package/v2Components/TemplatePreview/messages.js +0 -4
  71. package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +0 -1
  72. package/v2Containers/BeeEditor/index.js +90 -172
  73. package/v2Containers/CreativesContainer/SlideBoxContent.js +51 -127
  74. package/v2Containers/CreativesContainer/SlideBoxFooter.js +13 -163
  75. package/v2Containers/CreativesContainer/SlideBoxHeader.js +1 -2
  76. package/v2Containers/CreativesContainer/constants.js +0 -1
  77. package/v2Containers/CreativesContainer/index.js +46 -240
  78. package/v2Containers/CreativesContainer/messages.js +0 -8
  79. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +2 -11
  80. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +50 -38
  81. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -103
  82. package/v2Containers/Email/actions.js +0 -7
  83. package/v2Containers/Email/constants.js +1 -5
  84. package/v2Containers/Email/index.js +29 -234
  85. package/v2Containers/Email/messages.js +0 -32
  86. package/v2Containers/Email/reducer.js +1 -12
  87. package/v2Containers/Email/sagas.js +7 -61
  88. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
  89. package/v2Containers/Email/tests/reducer.test.js +0 -46
  90. package/v2Containers/Email/tests/sagas.test.js +29 -320
  91. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +21 -211
  92. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
  93. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
  94. package/v2Containers/EmailWrapper/constants.js +0 -2
  95. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +77 -629
  96. package/v2Containers/EmailWrapper/index.js +23 -103
  97. package/v2Containers/EmailWrapper/messages.js +1 -65
  98. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +214 -0
  99. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -594
  100. package/v2Containers/FTP/index.js +1 -1
  101. package/v2Containers/InApp/actions.js +0 -7
  102. package/v2Containers/InApp/constants.js +4 -20
  103. package/v2Containers/InApp/index.js +360 -802
  104. package/v2Containers/InApp/index.scss +3 -4
  105. package/v2Containers/InApp/messages.js +3 -7
  106. package/v2Containers/InApp/reducer.js +3 -21
  107. package/v2Containers/InApp/sagas.js +9 -29
  108. package/v2Containers/InApp/selectors.js +5 -25
  109. package/v2Containers/InApp/tests/index.test.js +50 -154
  110. package/v2Containers/InApp/tests/reducer.test.js +0 -34
  111. package/v2Containers/InApp/tests/sagas.test.js +9 -61
  112. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +0 -3
  113. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +0 -2
  114. package/v2Containers/Line/Container/Text/index.js +1 -0
  115. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +0 -2
  116. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +0 -9
  117. package/v2Containers/MobilePushNew/index.js +1 -0
  118. package/v2Containers/Rcs/index.js +3 -0
  119. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +0 -12
  120. package/v2Containers/SmsTrai/Edit/index.js +1 -0
  121. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +0 -4
  122. package/v2Containers/TagList/index.js +19 -62
  123. package/v2Containers/Templates/_templates.scss +1 -60
  124. package/v2Containers/Templates/index.js +4 -89
  125. package/v2Containers/Templates/messages.js +0 -4
  126. package/v2Containers/TemplatesV2/TemplatesV2.style.js +2 -4
  127. package/v2Containers/Viber/index.js +1 -0
  128. package/v2Containers/WebPush/Create/index.js +1 -1
  129. package/v2Containers/WebPush/Create/utils/validation.js +2 -1
  130. package/v2Containers/Whatsapp/index.js +1 -0
  131. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +0 -34
  132. package/v2Containers/Zalo/index.js +1 -0
  133. package/v2Containers/Zalo/tests/index.test.js +1 -5
  134. package/v2Components/ErrorInfoNote/constants.js +0 -1
  135. package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +0 -870
  136. package/v2Components/HtmlEditor/components/ValidationPanel/constants.js +0 -6
  137. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -281
  138. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -294
  139. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
  140. package/v2Components/HtmlEditor/utils/validationConstants.js +0 -38
  141. package/v2Containers/BeePopupEditor/_beePopupEditor.scss +0 -14
  142. package/v2Containers/BeePopupEditor/constants.js +0 -10
  143. package/v2Containers/BeePopupEditor/index.js +0 -194
  144. package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
  145. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1246
  146. package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +0 -2472
  147. package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +0 -520
  148. package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +0 -956
  149. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
  150. package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
  151. package/v2Containers/InApp/tests/selectors.test.js +0 -612
  152. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -151
  153. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
  154. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -23
  155. package/v2Containers/InAppWrapper/constants.js +0 -16
  156. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
  157. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
  158. package/v2Containers/InAppWrapper/index.js +0 -148
  159. package/v2Containers/InAppWrapper/messages.js +0 -49
  160. package/v2Containers/InappAdvance/index.js +0 -1099
  161. package/v2Containers/InappAdvance/index.scss +0 -10
  162. package/v2Containers/InappAdvance/tests/index.test.js +0 -448
Binary file
package/assets/iOS.png CHANGED
Binary file
@@ -45,7 +45,6 @@ export const GIFT_CARDS = 'GIFT_CARDS';
45
45
  export const PROMO_ENGINE = 'PROMO_ENGINE';
46
46
  export const LIQUID_SUPPORT = 'ENABLE_LIQUID_SUPPORT';
47
47
  export const ENABLE_NEW_MPUSH = 'ENABLE_NEW_MPUSH';
48
- export const SUPPORT_CK_EDITOR = 'SUPPORT_CK_EDITOR';
49
48
  export const CUSTOM_TAG = 'CustomTagMessage';
50
49
  export const CUSTOMER_EXTENDED_FIELD = 'Customer extended fields';
51
50
  export const EXTENDED_TAG = 'ExtendedTagMessage';
@@ -170,7 +169,7 @@ export const JAPANESE_HIDE_DATE_TAGS = [
170
169
  "dd.mm.yy",
171
170
  "dd Mon",
172
171
  "dd/m/yyyy",
173
- ];
172
+ ];
174
173
 
175
174
  export const LIQUID_SUPPORTED_CHANNELS = [EMAIL, SMS, MOBILE_PUSH, INAPP];
176
175
 
package/initialReducer.js CHANGED
@@ -15,7 +15,6 @@ import galleryReducer from './v2Containers/Assets/Gallery/reducer';
15
15
  import CapCollapsibleLeftNavigationReducer from '@capillarytech/cap-ui-library/CapCollapsibleLeftNavigation/reducer';
16
16
  import { AIRA_REDUCER_DOMAIN, askAiraReducer } from '@capillarytech/cap-ui-library/CapAskAira';
17
17
  import previewAndTestReducer from './v2Components/TestAndPreviewSlidebox/reducer';
18
- import inAppReducer from './v2Containers/InApp/reducer';
19
18
 
20
19
  export const initialReducer = {
21
20
  language: languageProviderReducer,
@@ -34,5 +33,4 @@ export const initialReducer = {
34
33
  gallery: galleryReducer,
35
34
  navigationConfig: CapCollapsibleLeftNavigationReducer,
36
35
  previewAndTest: previewAndTestReducer,
37
- inApp: inAppReducer,
38
36
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@capillarytech/creatives-library",
3
3
  "author": "meharaj",
4
- "version": "8.0.262",
4
+ "version": "8.0.264",
5
5
  "description": "Capillary creatives ui",
6
6
  "main": "./index.js",
7
7
  "module": "./index.es.js",
package/services/api.js CHANGED
@@ -470,11 +470,6 @@ export const getCmsTemplateSettingsV2 = (cmsType, projectId, cmsMode, langId, is
470
470
  return API.get(url);
471
471
  };
472
472
 
473
- export const getCmsAccounts = (cmsType) => {
474
- const url = `${API_ENDPOINT}/cms/accounts?type=${cmsType}`;
475
- return API.get(url);
476
- };
477
-
478
473
  export const getCmsTemplateData = (cmsType, projectId, langId) => {
479
474
  const url = `${API_ENDPOINT}/cms/getContent?type=${cmsType}&projectId=${projectId}&langId=${langId}`;
480
475
  return API.get(url);
@@ -730,9 +725,4 @@ export const getAssetStatus = (type, assetId) => {
730
725
  return request(url, getAPICallObject('GET'));
731
726
  };
732
727
 
733
- export const getBeePopupBuilderToken = () => {
734
- const url = `${API_ENDPOINT}/common/getInappTokenData`;
735
- return request(url, getAPICallObject('GET'));
736
- };
737
-
738
728
  export {request, getAPICallObject};
@@ -26,8 +26,6 @@ import {
26
26
  updateMetaConfig,
27
27
  getMediaDetails,
28
28
  getAssetStatus,
29
- getBeePopupBuilderToken,
30
- getCmsAccounts,
31
29
  } from '../api';
32
30
  import { mockData } from './mockData';
33
31
  import getSchema from '../getSchema';
@@ -975,35 +973,3 @@ describe('getAssetStatus', () => {
975
973
  expect(callArgs[0]).toContain('/assets/video/asset-456/status');
976
974
  });
977
975
  });
978
-
979
- describe('getBeePopupBuilderToken', () => {
980
- it('should return correct response', async () => {
981
- global.fetch.mockReturnValue(Promise.resolve({
982
- status: 200,
983
- json: () => Promise.resolve({
984
- status: 200,
985
- response: 'test',
986
- }),
987
- }));
988
- const result = await getBeePopupBuilderToken();
989
- expect(result).toEqual({
990
- status: 200,
991
- response: 'test',
992
- });
993
- });
994
- });
995
-
996
- describe('getCmsAccounts', () => {
997
- it('should return a promise (line 473-476)', () => {
998
- // Similar to other API tests, just verify it returns a Promise
999
- const result = getCmsAccounts('bee');
1000
- expect(result).toBeInstanceOf(Promise);
1001
- });
1002
-
1003
- it('should be callable with cmsType parameter', () => {
1004
- // Verify function exists and can be called
1005
- expect(typeof getCmsAccounts).toBe('function');
1006
- const result = getCmsAccounts('bee');
1007
- expect(result).toBeInstanceOf(Promise);
1008
- });
1009
- });
@@ -17,7 +17,6 @@ import { initialReducer } from '../../../initialReducer';
17
17
  import { mockInitialState } from './mocks/initialState';
18
18
  import TemplatesV2 from '../../../v2Containers/TemplatesV2';
19
19
  import globalMessages from '../../../v2Containers/Cap/messages';
20
- import rcsMessages from '../../../v2Containers/Rcs/messages';
21
20
  import * as helper from './helper';
22
21
 
23
22
  jest.mock('@capillarytech/cap-ui-utils', () => ({
@@ -148,16 +147,13 @@ describe("Creatives testing template creation", () => {
148
147
  fireEvent.change(templateNameInput, {
149
148
  target: { value: 'rcs_test_template' },
150
149
  });
151
- const richCardOption = await creativesScreen.findByText(/rich card/i);
152
- fireEvent.click(richCardOption);
153
- const imageRadioBtn = await creativesScreen.findByRole('radio', {
154
- name: /image/i,
155
- });
150
+ const imageRadioBtn = creativesScreen.getByText(/image/i);
156
151
  fireEvent.click(imageRadioBtn);
157
- const imageUploader = await creativesScreen.findByText(
158
- /drag and drop image here/i,
159
- );
152
+ const imageUploader = await creativesScreen.findByText(/drag and drop image here/i);
160
153
  expect(imageUploader).toBeInTheDocument();
154
+ const noneRadioBtn = await creativesScreen.findByText(/none/i);
155
+ fireEvent.click(noneRadioBtn);
156
+ expect(imageUploader).not.toBeInTheDocument();
161
157
 
162
158
  // Enter the template title
163
159
  const templateTitleInput = await creativesScreen.findByTestId(
@@ -179,7 +175,7 @@ describe("Creatives testing template creation", () => {
179
175
 
180
176
  // click on Done button
181
177
  const doneButton = creativesScreen.getByRole('button', {
182
- name: rcsMessages.sendForApprovalButtonLabel.defaultMessage,
178
+ name: globalMessages.done.defaultMessage,
183
179
  });
184
180
  await userEvent.click(doneButton);
185
181
  expect(createButton).toBeInTheDocument();
@@ -192,13 +188,11 @@ describe("Creatives testing template creation", () => {
192
188
  name: /rcs/i,
193
189
  });
194
190
  await userEvent.click(rcs);
195
- const createButton = await creativesScreen.findByRole('button', {
191
+ const createButton = creativesScreen.getByRole('button', {
196
192
  name: /create new/i,
197
193
  });
198
194
  await waitFor(() => expect(createButton).toBeEnabled(),{ timeout: 5000, interval: 100 });
199
195
  await userEvent.click(createButton);
200
- const richCardOption = await creativesScreen.findByText(/rich card/i);
201
- fireEvent.click(richCardOption);
202
196
  const templateNameInput = await creativesScreen.findByTestId(
203
197
  /template_name/,
204
198
  {},
@@ -223,14 +217,38 @@ describe("Creatives testing template creation", () => {
223
217
  fireEvent.change(templateTextInput, {
224
218
  target: { value: 'rcs_template_text' },
225
219
  });
226
- const addButton = creativesScreen.getByRole('button', {
227
- name: /add button/i,
220
+ const ctaCheckBox = creativesScreen.getByText(/call to action/i);
221
+ fireEvent.click(ctaCheckBox);
222
+ const doneButton = creativesScreen.getByRole('button', {
223
+ name: globalMessages.done.defaultMessage,
228
224
  });
229
- fireEvent.click(addButton);
230
- const ctaBtnText = creativesScreen.getByPlaceholderText(/enter button text/i);
225
+ //done button will be disabled cta button is not configured
226
+ expect(doneButton).toBeDisabled();
227
+
228
+ //configuring cta button
229
+ //accessing cta button textBox by char limit
230
+ const textLimit = creativesScreen.getByText(/0 \/ 20/i);
231
+ const ctaBtnText = textLimit.parentElement.previousSibling;
232
+
233
+ //configuring CTA button text and URL
231
234
  fireEvent.change(ctaBtnText, {
232
235
  target: { value: 'cta_button' },
233
236
  });
237
+ const ctaLink = await creativesScreen.findByTestId(
238
+ /cta_btn_link/,
239
+ {},
240
+ );
241
+ fireEvent.change(ctaLink, {
242
+ target: { value: 'invalid url' },
243
+ });
244
+ const urlError = creativesScreen.getByText(/button url is not valid/i);
245
+ expect(urlError).toBeInTheDocument();
246
+ fireEvent.change(ctaLink, {
247
+ target: { value: 'https://capillarytech.com/' },
248
+ });
249
+ expect(urlError).not.toBeInTheDocument();
250
+ //saving the template
251
+ fireEvent.click(doneButton);
234
252
  expect(createButton).toBeInTheDocument();
235
253
  });
236
254
 
@@ -1558,25 +1558,6 @@ export const whatsappAccount = {
1558
1558
  response: []
1559
1559
  };
1560
1560
 
1561
- export const rcsAccount = {
1562
- success: true,
1563
- status: {
1564
- isError: false,
1565
- code: 200,
1566
- message: "success",
1567
- },
1568
- message: "WeCRM Account details fetched",
1569
- response: [
1570
- {
1571
- name: "RCS Account",
1572
- sourceAccountIdentifier: "rcs_account",
1573
- configs: {
1574
- accessToken: "rcs_access_token",
1575
- },
1576
- },
1577
- ],
1578
- };
1579
-
1580
1561
  export const mpushAccount = {
1581
1562
  success: true,
1582
1563
  status: {
@@ -1735,18 +1716,7 @@ export const emailTemplates = {
1735
1716
 
1736
1717
  export const domainProperties = {
1737
1718
  entity:{
1738
- WHATSAPP:[],
1739
- RCS: [
1740
- {
1741
- domainProperties: {
1742
- hostName: "rcs-host",
1743
- connectionProperties: {
1744
- sourceAccountIdentifier: "rcs_account",
1745
- account_sid: "rcs_account",
1746
- },
1747
- },
1748
- },
1749
- ],
1719
+ WHATSAPP:[]
1750
1720
  },
1751
1721
  warnings:[]
1752
1722
  };
@@ -36,8 +36,6 @@ export const server = setupServer(
36
36
  rest.get(`${API_ENDPOINT}/meta/wecrm`, (req, res, ctx) => {
37
37
  const sourceName = req.url.searchParams.get('source_name');
38
38
  switch (sourceName) {
39
- case 'RCS':
40
- return res(ctx.status(200), ctx.json(apiResponse.rcsAccount));
41
39
  case 'WHATSAPP':
42
40
  return res(ctx.status(200), ctx.json(apiResponse.whatsappAccount));
43
41
  case 'VIBER':
package/utils/common.js CHANGED
@@ -23,7 +23,6 @@ import {
23
23
  ENABLE_WECHAT,
24
24
  ENABLE_WEBPUSH,
25
25
  LIQUID_SUPPORT,
26
- SUPPORT_CK_EDITOR,
27
26
  ENABLE_NEW_MPUSH
28
27
  } from '../constants/unified';
29
28
  import { apiMessageFormatHandler } from './commonUtils';
@@ -97,10 +96,6 @@ export const hasLiquidSupportFeature = Auth.hasFeatureAccess.bind(
97
96
  LIQUID_SUPPORT,
98
97
  );
99
98
 
100
- export const hasSupportCKEditor = Auth.hasFeatureAccess.bind(
101
- null,
102
- SUPPORT_CK_EDITOR,
103
- );
104
99
 
105
100
  export const hasGiftVoucherFeature = Auth.hasFeatureAccess.bind(
106
101
  null,
@@ -173,30 +173,20 @@ export const validateLiquidTemplateContent = async (
173
173
  // Handle API errors or empty content
174
174
  if (result?.errors?.length > 0 || !validString || isError) {
175
175
  let standardErrors = [];
176
- let liquidErrors = [];
177
-
178
- // Empty content errors are NOT from liquid endpoints, so they go to standardErrors
179
176
  if (!validString) {
180
177
  standardErrors = [emptyBodyError];
181
178
  }
182
-
183
- // IMPORTANT: Errors from extractTags and liquidValidation endpoints should ALWAYS be categorized as liquidErrors
184
- // These endpoints are: /extractTags and /ask-aira-service/creatives_ai/liquidValidation
185
- // Only errors from these endpoints should appear in Liquid Issues tab
186
- if (result && Array.isArray(result?.errors) && result.errors.length > 0) {
187
- // Errors from extractTags or liquidValidation endpoints
188
- liquidErrors = result.errors.map((error) => {
179
+ let liquidErrors;
180
+ if (result && Array.isArray(result?.errors)) {
181
+ liquidErrors = result?.errors?.map((error) => {
189
182
  const message = typeof error?.message === "string"
190
183
  ? error.message
191
184
  : somethingWrongMsg;
192
185
  return message;
193
186
  });
194
- } else if (isError) {
195
- // If isError is true, it means the API call to extractTags/liquidValidation failed
196
- // This is also a liquid endpoint error, so categorize as liquidErrors
187
+ } else {
197
188
  liquidErrors = [somethingWrongMsg];
198
189
  }
199
-
200
190
  onError({
201
191
  standardErrors,
202
192
  liquidErrors,
@@ -408,20 +398,7 @@ export const validateMobilePushContent = async (formData, options) => {
408
398
  // Helper function to extract content for a platform
409
399
  export const extractContent = (platformData) => {
410
400
  if (!platformData) return '';
411
- const { title, message, ctas, isBEEeditor, beeHtml } = platformData;
412
-
413
- // For BEE editor, extract content from beeHtml
414
- if (isBEEeditor && beeHtml) {
415
- // beeHtml can be an object with value property or a string
416
- const beeHtmlContent = typeof beeHtml === 'string' ? beeHtml : (beeHtml?.value || '');
417
- return [
418
- title,
419
- beeHtmlContent,
420
- ...((ctas?.map((cta) => cta?.text || cta?.actionLink)) || []),
421
- ].filter(Boolean).join(' ');
422
- }
423
-
424
- // For regular content
401
+ const { title, message, ctas } = platformData;
425
402
  return [
426
403
  title,
427
404
  message,
@@ -187,6 +187,7 @@ export const validateTags = ({
187
187
  location,
188
188
  tagModule,
189
189
  eventContextTags,
190
+ isFullMode,
190
191
  }) => {
191
192
  const tags = tagsParam;
192
193
  const injectedTags = transformInjectedTags(injectedTagsParams);
@@ -200,7 +201,7 @@ export const validateTags = ({
200
201
  unsupportedTags: [],
201
202
  isBraceError: false,
202
203
  };
203
- if (tags && tags.length) {
204
+ if (tags && tags.length && !isFullMode) {
204
205
  lodashForEach(tags, ({
205
206
  definition: {
206
207
  supportedModules,
@@ -1376,228 +1376,4 @@ describe("validateCarouselCards", () => {
1376
1376
  expect(result.isValid).toBe(true);
1377
1377
  });
1378
1378
  });
1379
-
1380
- describe('extractContent BEE Editor Logic (L404-L412)', () => {
1381
- it('extracts content from beeHtml as string', () => {
1382
- const platformData = {
1383
- title: 'Test Title',
1384
- isBEEeditor: true,
1385
- beeHtml: '<p>BEE HTML Content</p>',
1386
- ctas: [
1387
- { text: 'Click Here', actionLink: 'https://example.com' },
1388
- ],
1389
- };
1390
-
1391
- const result = extractContent(platformData);
1392
-
1393
- expect(result).toContain(platformData.title);
1394
- expect(result).toContain(platformData.beeHtml);
1395
- expect(result).toContain(platformData.ctas[0].text);
1396
- });
1397
-
1398
- it('extracts content from beeHtml as object with value property', () => {
1399
- const platformData = {
1400
- title: 'Test Title',
1401
- isBEEeditor: true,
1402
- beeHtml: { value: '<p>BEE HTML from Object</p>' },
1403
- ctas: [
1404
- { text: 'Button Text' },
1405
- ],
1406
- };
1407
-
1408
- const result = extractContent(platformData);
1409
-
1410
- expect(result).toContain(platformData.title);
1411
- expect(result).toContain(platformData.beeHtml.value);
1412
- expect(result).toContain(platformData.ctas[0].text);
1413
- });
1414
-
1415
- it('handles beeHtml as object without value property', () => {
1416
- const platformData = {
1417
- title: 'Test Title',
1418
- isBEEeditor: true,
1419
- beeHtml: { someOtherProperty: 'data' },
1420
- ctas: [],
1421
- };
1422
-
1423
- const result = extractContent(platformData);
1424
-
1425
- // Should extract title and empty beeHtml (since value is undefined)
1426
- expect(result).toContain('Test Title');
1427
- expect(result).not.toContain('someOtherProperty');
1428
- });
1429
-
1430
- it('extracts ctas with text property', () => {
1431
- const platformData = {
1432
- title: 'Title',
1433
- isBEEeditor: true,
1434
- beeHtml: '<p>Content</p>',
1435
- ctas: [
1436
- { text: 'CTA Text 1' },
1437
- { text: 'CTA Text 2' },
1438
- ],
1439
- };
1440
-
1441
- const result = extractContent(platformData);
1442
-
1443
- expect(result).toContain('CTA Text 1');
1444
- expect(result).toContain('CTA Text 2');
1445
- });
1446
-
1447
- it('extracts ctas with actionLink when text is missing', () => {
1448
- const platformData = {
1449
- title: 'Title',
1450
- isBEEeditor: true,
1451
- beeHtml: '<p>Content</p>',
1452
- ctas: [
1453
- { actionLink: 'https://link1.com' },
1454
- { actionLink: 'https://link2.com' },
1455
- ],
1456
- };
1457
-
1458
- const result = extractContent(platformData);
1459
-
1460
- expect(result).toContain('https://link1.com');
1461
- expect(result).toContain('https://link2.com');
1462
- });
1463
-
1464
- it('filters out falsy values with filter(Boolean)', () => {
1465
- const platformData = {
1466
- title: '',
1467
- isBEEeditor: true,
1468
- beeHtml: null,
1469
- ctas: [
1470
- { text: null, actionLink: null },
1471
- { text: 'Valid Text' },
1472
- ],
1473
- };
1474
-
1475
- const result = extractContent(platformData);
1476
-
1477
- // Should only contain 'Valid Text' after filtering
1478
- expect(result).toBe('Valid Text');
1479
- });
1480
-
1481
- it('handles empty ctas array', () => {
1482
- const platformData = {
1483
- title: 'Title Only',
1484
- isBEEeditor: true,
1485
- beeHtml: '<p>BEE Content</p>',
1486
- ctas: [],
1487
- };
1488
-
1489
- const result = extractContent(platformData);
1490
-
1491
- expect(result).toContain('Title Only');
1492
- expect(result).toContain('<p>BEE Content</p>');
1493
- });
1494
-
1495
- it('handles undefined ctas', () => {
1496
- const platformData = {
1497
- title: 'Title',
1498
- isBEEeditor: true,
1499
- beeHtml: '<p>Content</p>',
1500
- ctas: undefined,
1501
- };
1502
-
1503
- const result = extractContent(platformData);
1504
-
1505
- expect(result).toContain('Title');
1506
- expect(result).toContain('<p>Content</p>');
1507
- });
1508
-
1509
- it('joins all content with spaces', () => {
1510
- const platformData = {
1511
- title: 'Title',
1512
- isBEEeditor: true,
1513
- beeHtml: 'HTML',
1514
- ctas: [
1515
- { text: 'CTA1' },
1516
- { text: 'CTA2' },
1517
- ],
1518
- };
1519
-
1520
- const result = extractContent(platformData);
1521
-
1522
- expect(result).toBe('Title HTML CTA1 CTA2');
1523
- });
1524
-
1525
- it('falls back to regular content when not BEE editor', () => {
1526
- const platformData = {
1527
- title: 'Title',
1528
- message: 'Message',
1529
- isBEEeditor: false,
1530
- beeHtml: '<p>Should be ignored</p>',
1531
- ctas: [
1532
- { text: 'CTA' },
1533
- ],
1534
- };
1535
-
1536
- const result = extractContent(platformData);
1537
-
1538
- expect(result).toContain('Title');
1539
- expect(result).toContain('Message');
1540
- expect(result).toContain('CTA');
1541
- expect(result).not.toContain('<p>Should be ignored</p>');
1542
- });
1543
-
1544
- it('handles null beeHtml', () => {
1545
- const platformData = {
1546
- title: 'Title',
1547
- isBEEeditor: true,
1548
- beeHtml: null,
1549
- ctas: [{ text: 'CTA' }],
1550
- };
1551
-
1552
- const result = extractContent(platformData);
1553
-
1554
- expect(result).toContain('Title');
1555
- expect(result).toContain('CTA');
1556
- });
1557
-
1558
- it('handles undefined beeHtml', () => {
1559
- const platformData = {
1560
- title: 'Title',
1561
- isBEEeditor: true,
1562
- beeHtml: undefined,
1563
- ctas: [],
1564
- };
1565
-
1566
- const result = extractContent(platformData);
1567
-
1568
- expect(result).toBe('Title');
1569
- });
1570
-
1571
- it('handles complex ctas with both text and actionLink', () => {
1572
- const platformData = {
1573
- title: 'Title',
1574
- isBEEeditor: true,
1575
- beeHtml: 'Content',
1576
- ctas: [
1577
- { text: 'CTA Text', actionLink: 'https://example.com' },
1578
- ],
1579
- };
1580
-
1581
- const result = extractContent(platformData);
1582
-
1583
- // Should prefer text over actionLink
1584
- expect(result).toContain('CTA Text');
1585
- expect(result).toContain('Title');
1586
- expect(result).toContain('Content');
1587
- });
1588
-
1589
- it('handles empty string beeHtml', () => {
1590
- const platformData = {
1591
- title: 'Title',
1592
- isBEEeditor: true,
1593
- beeHtml: '',
1594
- ctas: [{ text: 'CTA' }],
1595
- };
1596
-
1597
- const result = extractContent(platformData);
1598
-
1599
- expect(result).toBe('Title CTA');
1600
- });
1601
- });
1602
1379
  });
1603
-
@@ -101,6 +101,7 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
101
101
  const contentType = detectMediaContentType(templateConfig);
102
102
 
103
103
  if (contentType === MEDIA_CONTENT_TYPE.NONE) {
104
+ console.log('No media content detected, returning original config');
104
105
  return templateConfig;
105
106
  }
106
107
 
@@ -108,19 +109,24 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
108
109
  let transformDirection;
109
110
  if (forceDirection) {
110
111
  transformDirection = forceDirection;
112
+ console.log(`Forced transformation direction: ${transformDirection}`);
111
113
  } else {
112
114
  // Auto-detect based on content
113
115
  if (contentType === MEDIA_CONTENT_TYPE.URLS) {
114
116
  transformDirection = TRANSFORM_DIRECTION.FORWARD; // URLs → tags
117
+ console.log('Detected URLs, applying forward transformation (URLs → tags)');
115
118
  } else if (contentType === MEDIA_CONTENT_TYPE.TAGS) {
116
119
  transformDirection = TRANSFORM_DIRECTION.REVERSE; // tags → URLs
120
+ console.log('Detected media_content tags, applying reverse transformation (tags → URLs)');
117
121
  } else if (contentType === MEDIA_CONTENT_TYPE.MIXED) {
118
122
  transformDirection = TRANSFORM_DIRECTION.SMART; // Handle mixed content intelligently
123
+ console.log('Detected mixed content, applying smart transformation');
119
124
  }
120
125
  }
121
126
 
122
127
  const newConfig = cloneDeep(templateConfig);
123
128
  try {
129
+ console.log(`Fetching media details for ${transformDirection} transformation, ID: ${mediaDetailsId}`);
124
130
 
125
131
  // Fetch media details mapping from API
126
132
  const response = await getMediaDetails({ id: mediaDetailsId })
@@ -139,6 +145,7 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
139
145
  idToUrlMapping[mediaId] = url;
140
146
  });
141
147
 
148
+ console.log(`Processing ${Object.keys(urlToIdMapping).length} media mappings`);
142
149
 
143
150
  // Apply transformations based on direction
144
151
  newConfig?.cards?.forEach(card => {
@@ -150,6 +157,7 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
150
157
  // Forward transformation: URL → tag
151
158
  const mediaDetailId = urlToIdMapping[currentUrl];
152
159
  if (mediaDetailId) {
160
+ console.log(`Forward: ${currentUrl} → {{media_content(${mediaDetailId})}}`);
153
161
  card.media.url = `{{media_content(${mediaDetailId})}}`;
154
162
  } else {
155
163
  console.warn(`No media detail ID found for URL: ${currentUrl}`);
@@ -161,6 +169,7 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
161
169
  if (mediaId) {
162
170
  const actualUrl = idToUrlMapping[mediaId];
163
171
  if (actualUrl) {
172
+ console.log(`Reverse: {{media_content(${mediaId})}} → ${actualUrl}`);
164
173
  card.media.url = actualUrl;
165
174
  } else {
166
175
  console.warn(`No URL found for media ID: ${mediaId}`);
@@ -176,6 +185,7 @@ export async function transformTemplateConfigWithMediaDetails(templateConfig, ch
176
185
  console.error('Failed to fetch media details for transformation:', error);
177
186
 
178
187
  // Fallback: try to extract/convert what we can without API
188
+ console.log('Falling back to URL extraction method');
179
189
  newConfig.cards.forEach(card => {
180
190
  if (card.media && card.media.url) {
181
191
  if (transformDirection === TRANSFORM_DIRECTION.FORWARD) {