@capillarytech/creatives-library 8.0.345-alpha.12 → 8.0.345-alpha.13

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 (138) hide show
  1. package/constants/unified.js +0 -29
  2. package/package.json +1 -1
  3. package/services/api.js +20 -0
  4. package/services/tests/api.test.js +59 -13
  5. package/utils/commonUtils.js +1 -19
  6. package/v2Components/CapActionButton/constants.js +0 -7
  7. package/v2Components/CapActionButton/index.js +109 -167
  8. package/v2Components/CapActionButton/index.scss +6 -157
  9. package/v2Components/CapActionButton/messages.js +3 -19
  10. package/v2Components/CapActionButton/tests/index.test.js +17 -41
  11. package/v2Components/CapCustomSkeleton/index.js +1 -1
  12. package/v2Components/CapCustomSkeleton/tests/__snapshots__/index.test.js.snap +12 -12
  13. package/v2Components/CapTagList/index.js +0 -10
  14. package/v2Components/CommonTestAndPreview/CustomValuesEditor.js +49 -70
  15. package/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +2 -8
  16. package/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +21 -207
  17. package/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +0 -16
  18. package/v2Components/CommonTestAndPreview/DeliverySettings/index.js +10 -85
  19. package/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +0 -30
  20. package/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +11 -79
  21. package/v2Components/CommonTestAndPreview/SendTestMessage.js +5 -10
  22. package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js +15 -160
  23. package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +76 -341
  24. package/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +4 -133
  25. package/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +0 -11
  26. package/v2Components/CommonTestAndPreview/constants.js +2 -38
  27. package/v2Components/CommonTestAndPreview/index.js +186 -676
  28. package/v2Components/CommonTestAndPreview/messages.js +3 -49
  29. package/v2Components/CommonTestAndPreview/sagas.js +6 -15
  30. package/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +284 -308
  31. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +65 -231
  32. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +5 -118
  33. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +0 -341
  34. package/v2Components/CommonTestAndPreview/tests/PreviewSection.test.js +1 -8
  35. package/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +13 -34
  36. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/RcsPreviewContent.test.js +283 -281
  37. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +1 -199
  38. package/v2Components/CommonTestAndPreview/tests/index.test.js +4 -132
  39. package/v2Components/CommonTestAndPreview/tests/sagas.test.js +2 -2
  40. package/v2Components/FormBuilder/index.js +10 -8
  41. package/v2Components/TemplatePreview/_templatePreview.scss +23 -33
  42. package/v2Components/TemplatePreview/index.js +28 -143
  43. package/v2Components/TemplatePreview/tests/index.test.js +0 -142
  44. package/v2Components/TestAndPreviewSlidebox/index.js +1 -13
  45. package/v2Components/TestAndPreviewSlidebox/sagas.js +4 -11
  46. package/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +1 -3
  47. package/v2Containers/Assets/images/archive_Empty_Illustration.svg +9 -0
  48. package/v2Containers/CreativesContainer/SlideBoxContent.js +4 -36
  49. package/v2Containers/CreativesContainer/SlideBoxFooter.js +4 -11
  50. package/v2Containers/CreativesContainer/SlideBoxHeader.js +4 -29
  51. package/v2Containers/CreativesContainer/constants.js +0 -9
  52. package/v2Containers/CreativesContainer/index.js +108 -300
  53. package/v2Containers/CreativesContainer/index.scss +1 -51
  54. package/v2Containers/CreativesContainer/messages.js +4 -0
  55. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +34 -78
  56. package/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +16 -79
  57. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +0 -8
  58. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +98 -357
  59. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +18 -20
  60. package/v2Containers/CreativesContainer/tests/index.test.js +9 -71
  61. package/v2Containers/Rcs/constants.js +8 -119
  62. package/v2Containers/Rcs/index.js +812 -2375
  63. package/v2Containers/Rcs/index.scss +6 -276
  64. package/v2Containers/Rcs/messages.js +3 -38
  65. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +70345 -98302
  66. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +5 -0
  67. package/v2Containers/Rcs/tests/index.test.js +121 -152
  68. package/v2Containers/Rcs/tests/mockData.js +0 -38
  69. package/v2Containers/Rcs/tests/utils.test.js +30 -646
  70. package/v2Containers/Rcs/utils.js +11 -478
  71. package/v2Containers/Sms/Create/index.js +40 -100
  72. package/v2Containers/SmsTrai/Create/index.js +4 -9
  73. package/v2Containers/SmsTrai/Edit/constants.js +0 -2
  74. package/v2Containers/SmsTrai/Edit/index.js +130 -636
  75. package/v2Containers/SmsTrai/Edit/messages.js +4 -14
  76. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +2296 -4249
  77. package/v2Containers/SmsWrapper/index.js +8 -37
  78. package/v2Containers/TagList/index.js +0 -6
  79. package/v2Containers/Templates/ChannelTypeIllustration.js +23 -6
  80. package/v2Containers/Templates/_templates.scss +126 -181
  81. package/v2Containers/Templates/actions.js +36 -11
  82. package/v2Containers/Templates/constants.js +23 -2
  83. package/v2Containers/Templates/index.js +333 -142
  84. package/v2Containers/Templates/messages.js +68 -0
  85. package/v2Containers/Templates/reducer.js +68 -0
  86. package/v2Containers/Templates/sagas.js +98 -55
  87. package/v2Containers/Templates/selectors.js +12 -0
  88. package/v2Containers/Templates/tests/ChannelTypeIllustration.test.js +12 -0
  89. package/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1256 -1042
  90. package/v2Containers/Templates/tests/index.test.js +6 -0
  91. package/v2Containers/Templates/tests/reducer.test.js +178 -0
  92. package/v2Containers/Templates/tests/sagas.test.js +436 -200
  93. package/v2Containers/Templates/tests/selector.test.js +32 -0
  94. package/v2Containers/TemplatesV2/TemplatesV2.style.js +1 -72
  95. package/v2Containers/TemplatesV2/index.js +23 -86
  96. package/v2Containers/Whatsapp/index.js +20 -3
  97. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +34 -578
  98. package/utils/rcsPayloadUtils.js +0 -92
  99. package/utils/templateVarUtils.js +0 -201
  100. package/utils/tests/templateVarUtils.test.js +0 -204
  101. package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js.rej +0 -18
  102. package/v2Components/CommonTestAndPreview/previewApiUtils.js +0 -59
  103. package/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +0 -67
  104. package/v2Components/SmsFallback/SmsFallbackLocalSelector.js +0 -87
  105. package/v2Components/SmsFallback/constants.js +0 -73
  106. package/v2Components/SmsFallback/index.js +0 -955
  107. package/v2Components/SmsFallback/index.scss +0 -265
  108. package/v2Components/SmsFallback/messages.js +0 -78
  109. package/v2Components/SmsFallback/smsFallbackUtils.js +0 -118
  110. package/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +0 -50
  111. package/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +0 -147
  112. package/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +0 -304
  113. package/v2Components/SmsFallback/tests/smsFallbackUi.test.js +0 -197
  114. package/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +0 -277
  115. package/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +0 -422
  116. package/v2Components/SmsFallback/useLocalTemplateList.js +0 -92
  117. package/v2Components/TemplatePreview/constants.js +0 -2
  118. package/v2Components/VarSegmentMessageEditor/constants.js +0 -2
  119. package/v2Components/VarSegmentMessageEditor/index.js +0 -125
  120. package/v2Components/VarSegmentMessageEditor/index.scss +0 -46
  121. package/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +0 -43
  122. package/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +0 -67
  123. package/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +0 -90
  124. package/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +0 -258
  125. package/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +0 -125
  126. package/v2Containers/Rcs/index.js.rej +0 -1336
  127. package/v2Containers/Rcs/index.scss.rej +0 -74
  128. package/v2Containers/Rcs/rcsLibraryHydrationUtils.js +0 -225
  129. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap.rej +0 -128
  130. package/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +0 -318
  131. package/v2Containers/Sms/smsFormDataHelpers.js +0 -67
  132. package/v2Containers/Sms/tests/smsFormDataHelpers.test.js +0 -253
  133. package/v2Containers/SmsTrai/Edit/index.scss +0 -121
  134. package/v2Containers/Templates/TemplatesActionBar.js +0 -101
  135. package/v2Containers/Templates/tests/TemplatesActionBar.test.js +0 -120
  136. package/v2Containers/Templates/tests/smsTemplatesListApi.test.js +0 -180
  137. package/v2Containers/Templates/utils/smsTemplatesListApi.js +0 -79
  138. package/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +0 -131
@@ -52,7 +52,6 @@ import { QUICK_REPLY, WHATSAPP_CATEGORIES, PHONE_NUMBER } from '../../v2Containe
52
52
  import { RCS_BUTTON_TYPES, LEFT, HORIZONTAL, VERTICAL, RIGHT} from '../../v2Containers/Rcs/constants';
53
53
  import { ANDROID, INAPP_MESSAGE_LAYOUT_TYPES } from '../../v2Containers/InApp/constants';
54
54
  import { CAROUSEL } from '../../v2Containers/MobilePushNew/constants';
55
- import { TEMPLATE_VAR_REGEX } from './constants';
56
55
 
57
56
  const wechatBodyNew = require('./assets/images/wechat_mobile_android.svg');
58
57
  const smsMobileAndroid = require('./assets/images/sms_mobile_android.svg');
@@ -235,23 +234,7 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
235
234
  let content = channel && channel.toLowerCase() === 'sms' ? [this.props.content] : this.props.content;
236
235
  const { formatMessage } = intl;
237
236
  const { rcsPreviewContent, inAppPreviewContent, viberPreviewContent, isBeeFreeTemplate } = content || {};
238
- const normalizedRcsPreviewContent = Array.isArray(rcsPreviewContent)
239
- ? { carouselData: rcsPreviewContent }
240
- : (rcsPreviewContent || {});
241
- const {
242
- rcsImageSrc,
243
- rcsVideoSrc,
244
- rcsTitle,
245
- rcsDesc,
246
- rcsSuggestions,
247
- carouselData: rcsCarouselData,
248
- rcsCarouselData: rcsCarouselDataAlt,
249
- cardVarMapped: rcsCardVarMapped,
250
- } = normalizedRcsPreviewContent;
251
- const resolvedRcsCarouselData =
252
- Array.isArray(rcsCarouselData) && rcsCarouselData.length > 0
253
- ? rcsCarouselData
254
- : rcsCarouselDataAlt;
237
+ const { rcsImageSrc, rcsVideoSrc, rcsTitle, rcsDesc, rcsSuggestions } = rcsPreviewContent || {};
255
238
  const {
256
239
  videoParams,
257
240
  imageURL,
@@ -332,18 +315,6 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
332
315
  'flex-shrink': 0,
333
316
  'left': 0,
334
317
  };
335
-
336
- const resolveVarsWithMap = (input, varMap) => {
337
- if (input === null || input === undefined) return '';
338
- const str = typeof input === 'string' ? input : String(input);
339
- return str.replace(TEMPLATE_VAR_REGEX, (token, varName) => {
340
- const mappedValue = varMap?.[varName];
341
- if (mappedValue === null || mappedValue === undefined || String(mappedValue) === '') {
342
- return token;
343
- }
344
- return String(mappedValue);
345
- });
346
- };
347
318
  const getVideoContent = ({
348
319
  video,
349
320
  actionUrl,
@@ -500,15 +471,13 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
500
471
  const whatsappUpdatedAccountName = whatsappAccountName || templateData?.versions?.base?.content?.whatsapp?.accountName || '';
501
472
  const whatsappUpdatedLen = whatsappContentLen !== undefined ? whatsappContentLen : content?.charCount;
502
473
 
503
- const renderRcsSuggestionsPreview = (suggestionsArg) => {
474
+ const renderRcsSuggestionsPreview = () => {
504
475
  const renderArray = [];
505
- const suggestions = Array.isArray(suggestionsArg) ? suggestionsArg : (rcsSuggestions || []);
506
- (suggestions || []).forEach((suggestion, idx) => {
507
- const suggestionKey = `${suggestion?.type || 'unknown'}-${suggestion?.text || ''}-${idx}`;
508
- renderArray.push(<CapDivider key={`rcs-divider-${suggestionKey}`} className="whatsapp-divider" />);
476
+ (rcsSuggestions || []).forEach((suggestion) => {
477
+ renderArray.push(<CapDivider className="whatsapp-divider" />);
509
478
  if (suggestion.type === RCS_BUTTON_TYPES.QUICK_REPLY) {
510
479
  renderArray.push(
511
- <CapLabel key={`rcs-suggestion-${suggestionKey}`} type="label21" className="rcs-cta-preview">
480
+ <CapLabel type="label21" className="rcs-cta-preview">
512
481
  <CapIcon
513
482
  type='small-link'
514
483
  size="xs"
@@ -518,14 +487,14 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
518
487
  );
519
488
  } else if (suggestion.type === RCS_BUTTON_TYPES.CTA) {
520
489
  renderArray.push(
521
- <CapLabel key={`rcs-suggestion-${suggestionKey}`} type="label21" className="rcs-cta-preview">
490
+ <CapLabel type="label21" className="rcs-cta-preview">
522
491
  <CapIcon type="launch" size="xs" />
523
492
  {suggestion.text}
524
493
  </CapLabel>,
525
494
  );
526
495
  } else if (suggestion.type === RCS_BUTTON_TYPES.PHONE_NUMBER) {
527
496
  renderArray.push(
528
- <CapLabel key={`rcs-suggestion-${suggestionKey}`} type="label21" className="rcs-cta-preview">
497
+ <CapLabel type="label21" className="rcs-cta-preview">
529
498
  <CapIcon type="call" size="xs" />
530
499
  {suggestion.text}
531
500
  </CapLabel>,
@@ -544,7 +513,7 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
544
513
  className="message-pop-item align-left rcs-content"
545
514
  fontWeight="bold"
546
515
  >
547
- {resolveVarsWithMap(rcsTitle, rcsCardVarMapped)}
516
+ {rcsTitle}
548
517
  </CapLabel>
549
518
  <CapDivider className="whatsapp-divider" />
550
519
  </>
@@ -554,7 +523,7 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
554
523
  type="label5"
555
524
  className="message-pop-item align-left rcs-desc rcs-content"
556
525
  >
557
- {resolveVarsWithMap(rcsDesc, rcsCardVarMapped)}
526
+ {rcsDesc}
558
527
  </CapLabel>
559
528
  )}
560
529
  {renderRcsSuggestionsPreview()}
@@ -571,134 +540,50 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
571
540
  />
572
541
  )}
573
542
  {rcsVideoSrc && (
574
- <CapRow className="video-preview">
543
+ <div className="video-preview">
575
544
  <CapImage
576
545
  src={rcsVideoSrc}
577
546
  className="rcs-image"
578
547
  alt={formatMessage(messages.previewGenerated)}
579
548
  />
580
- <CapRow className="icon-position">
549
+ <div className="icon-position">
581
550
  <CapImage
582
551
  className="video-icon"
583
552
  src={videoPlay}
584
553
  />
585
- </CapRow>
586
- </CapRow>
554
+ </div>
555
+ </div>
587
556
  )}
588
557
  </>
589
558
  );
590
559
 
591
560
  const renderRcsPreviewContent = () => {
592
- const carouselCards = Array.isArray(resolvedRcsCarouselData) ? resolvedRcsCarouselData : [];
593
- if (carouselCards.length > 0) {
594
- return (
595
- <CapRow className="msg-container sms">
596
- <CapRow className="message-pop sms">
597
- <CapRow className="msg-container-carousel">
598
- <CapRow className="scroll-container">
599
- {carouselCards.map((card, idx) => {
600
- const key = `rcs-carousel-${idx}-${card?.bodyText || card?.imageSrc || card?.videoPreviewImg || ''}`;
601
- const isVideo = (card?.mediaType || '').toLowerCase() === 'video';
602
- const cardSuggestions = Array.isArray(card?.suggestions) ? card.suggestions : [];
603
- const effectiveCardVarMap = card?.cardVarMapped || rcsCardVarMapped;
604
- const suggestionsNode = cardSuggestions.length > 0
605
- ? renderRcsSuggestionsPreview(cardSuggestions)
606
- : null;
607
-
608
- const resolvedCardTitle = resolveVarsWithMap(card?.title, effectiveCardVarMap);
609
- const resolvedCardBodyText = resolveVarsWithMap(card?.bodyText, effectiveCardVarMap);
610
-
611
- return (
612
- <CapRow
613
- key={key}
614
- className="message-pop align-left message-pop-carousel rcs-carousel-card"
615
- >
616
- <CapRow className="whatsapp-content">
617
- {!isVideo && (
618
- <CapImage
619
- src={card?.imageSrc ? card.imageSrc : whatsappImageEmptyPreview}
620
- className="whatsapp-image"
621
- alt={formatMessage(messages.previewGenerated)}
622
- />
623
- )}
624
- {isVideo && (
625
- <CapTooltip title={formatMessage(messages.videoPreviewTooltip)}>
626
- <CapRow className="video-preview">
627
- <CapImage
628
- src={card?.videoPreviewImg ? card.videoPreviewImg : whatsappVideoEmptyPreview}
629
- className="whatsapp-image"
630
- alt={formatMessage(messages.previewGenerated)}
631
- />
632
- <CapRow className="icon-position">
633
- <CapImage className="video-icon" src={videoPlay} alt="Play" />
634
- </CapRow>
635
- </CapRow>
636
- </CapTooltip>
637
- )}
638
-
639
- {(resolvedCardTitle || resolvedCardBodyText) && (
640
- <CapRow className="carousel-content">
641
- {!!resolvedCardTitle && (
642
- <CapLabel
643
- type={card?.titleLabelType || 'label1'}
644
- className="carousel-title"
645
- >
646
- {resolvedCardTitle}
647
- </CapLabel>
648
- )}
649
- {!!resolvedCardBodyText && (
650
- <CapLabel
651
- type={card?.bodyLabelType || 'label2'}
652
- className="carousel-message"
653
- >
654
- {resolvedCardBodyText}
655
- </CapLabel>
656
- )}
657
- </CapRow>
658
- )}
659
-
660
- {!!suggestionsNode && (
661
- <>
662
- {suggestionsNode}
663
- </>
664
- )}
665
- </CapRow>
666
- </CapRow>
667
- );
668
- })}
669
- </CapRow>
670
- </CapRow>
671
- </CapRow>
672
- </CapRow>
673
- );
674
- }
675
-
676
561
  if (rcsOrientation === HORIZONTAL) {
677
562
  return rcsType === RIGHT ? (
678
- <CapRow className="msg-container sms">
679
- <CapRow className="message-pop sms horizontal">
563
+ <div className="msg-container sms">
564
+ <div className="message-pop sms horizontal">
680
565
  <CapColumn className="rcs-preview-text" span={12}>{renderTextPreviewContent()}</CapColumn>
681
566
  <CapColumn span={12}>{renderMediaPreviewContent()}</CapColumn>
682
- </CapRow>
683
- </CapRow>
567
+ </div>
568
+ </div>
684
569
 
685
570
  ) : (
686
- <CapRow className="msg-container sms">
687
- <CapRow className="message-pop sms horizontal">
571
+ <div className="msg-container sms">
572
+ <div className="message-pop sms horizontal">
688
573
  <CapColumn span={12}>{renderMediaPreviewContent()}</CapColumn>
689
574
  <CapColumn className="rcs-preview-text" span={12}>{renderTextPreviewContent()}</CapColumn>
690
- </CapRow>
691
- </CapRow>
575
+ </div>
576
+ </div>
692
577
  );
693
578
  }
694
579
 
695
580
  return (
696
- <CapRow className="msg-container sms">
697
- <CapRow className="message-pop sms">
581
+ <div className="msg-container sms">
582
+ <div className="message-pop sms">
698
583
  {renderMediaPreviewContent()}
699
584
  {renderTextPreviewContent()}
700
- </CapRow>
701
- </CapRow>
585
+ </div>
586
+ </div>
702
587
  );
703
588
  };
704
589
 
@@ -1406,14 +1291,14 @@ export class TemplatePreview extends React.Component { // eslint-disable-line re
1406
1291
  ""
1407
1292
  )}
1408
1293
  {channel?.toUpperCase() === RCS && (
1409
- <CapRow className="shell-v2 align-center rcs-preview">
1294
+ <div className="shell-v2 align-center rcs-preview">
1410
1295
  <CapImage
1411
1296
  className="preview-image"
1412
1297
  src={rcsIosPreview ? smsMobileIos : smsMobileAndroid}
1413
1298
  alt={formatMessage(messages.previewGenerated)}
1414
1299
  />
1415
1300
  {renderRcsPreviewContent()}
1416
- </CapRow>
1301
+ </div>
1417
1302
 
1418
1303
  )}
1419
1304
  {channel?.toUpperCase() === ZALO && (
@@ -1614,4 +1499,4 @@ TemplatePreview.propTypes = {
1614
1499
  rcsOrientation: PropTypes.string,
1615
1500
  };
1616
1501
 
1617
- export default (injectIntl(TemplatePreview));
1502
+ export default (injectIntl(TemplatePreview));
@@ -2,9 +2,6 @@ import React from 'react';
2
2
  import { shallowWithIntl } from '../../../helpers/intl-enzym-test-helpers';
3
3
 
4
4
  import { TemplatePreview } from '../index';
5
- import { RCS } from '../../../v2Containers/CreativesContainer/constants';
6
- import whatsappImageEmptyPreview from '../assets/images/empty_image_preview.svg';
7
- import whatsappVideoEmptyPreview from '../assets/images/empty_video_preview.svg';
8
5
 
9
6
  describe('Test Templates container', () => {
10
7
  let renderedComponent;
@@ -72,143 +69,4 @@ describe('Test Templates container', () => {
72
69
  });
73
70
  expect(renderedComponent).toMatchSnapshot();
74
71
  });
75
-
76
- describe('RCS carousel preview branches', () => {
77
- const buildRcsContent = (cards) => ({
78
- rcsPreviewContent: {
79
- carouselData: cards,
80
- },
81
- });
82
-
83
- const getNodesByClassName = (className) =>
84
- renderedComponent.findWhere((node) => node.prop('className') === className);
85
-
86
- it('renders image and video cards with proper media-specific markup', () => {
87
- renderFunction(
88
- RCS,
89
- buildRcsContent([
90
- {
91
- mediaType: 'image',
92
- imageSrc: 'https://example.com/image-card.jpg',
93
- bodyText: 'image body',
94
- suggestions: [],
95
- },
96
- {
97
- mediaType: 'video',
98
- videoPreviewImg: 'https://example.com/video-thumb.jpg',
99
- bodyText: 'video body',
100
- suggestions: [],
101
- },
102
- ]),
103
- '',
104
- 0,
105
- );
106
-
107
- // Video card should render tooltip/video icon path; image-only card should not.
108
- expect(renderedComponent.find('CapTooltip')).toHaveLength(1);
109
- expect(
110
- renderedComponent.findWhere((node) => node.prop('className') === 'video-icon')
111
- ).toHaveLength(1);
112
-
113
- // Both cards render media containers.
114
- expect(
115
- renderedComponent.findWhere((node) => node.prop('className') === 'whatsapp-image')
116
- ).toHaveLength(2);
117
- });
118
-
119
- it('renders per-card suggestions only for cards that provide suggestions', () => {
120
- renderFunction(
121
- RCS,
122
- buildRcsContent([
123
- {
124
- mediaType: 'image',
125
- imageSrc: 'https://example.com/with-suggestions.jpg',
126
- bodyText: 'has suggestions',
127
- suggestions: [
128
- { type: 'QUICK_REPLY', text: 'Reply 1' },
129
- { type: 'CTA', text: 'Visit' },
130
- ],
131
- },
132
- {
133
- mediaType: 'image',
134
- imageSrc: 'https://example.com/no-suggestions.jpg',
135
- bodyText: 'no suggestions',
136
- suggestions: [],
137
- },
138
- ]),
139
- '',
140
- 0,
141
- );
142
-
143
- // Suggestion labels/icons should be rendered only from first card.
144
- expect(getNodesByClassName('rcs-cta-preview')).toHaveLength(2);
145
- expect(getNodesByClassName('whatsapp-divider')).not.toHaveLength(0);
146
- });
147
-
148
- it('falls back to empty preview assets when image/video media src is missing', () => {
149
- renderFunction(
150
- RCS,
151
- buildRcsContent([
152
- {
153
- mediaType: 'image',
154
- bodyText: 'fallback image',
155
- suggestions: [],
156
- },
157
- {
158
- mediaType: 'video',
159
- bodyText: 'fallback video',
160
- suggestions: [],
161
- },
162
- ]),
163
- '',
164
- 0,
165
- );
166
-
167
- const mediaImageNodes = renderedComponent.findWhere(
168
- (node) => node.name() === 'CapImage' && node.prop('className') === 'whatsapp-image'
169
- );
170
- const mediaSrcs = mediaImageNodes.map((node) => node.prop('src'));
171
-
172
- expect(mediaSrcs).toContain(whatsappImageEmptyPreview);
173
- expect(mediaSrcs).toContain(whatsappVideoEmptyPreview);
174
- });
175
-
176
- it('generates unique carousel keys using rcs-carousel-<idx>-<bodyText|imageSrc|videoPreviewImg>', () => {
177
- renderFunction(
178
- RCS,
179
- buildRcsContent([
180
- {
181
- mediaType: 'image',
182
- imageSrc: 'https://example.com/one.jpg',
183
- bodyText: 'same body',
184
- suggestions: [],
185
- },
186
- {
187
- mediaType: 'image',
188
- imageSrc: 'https://example.com/two.jpg',
189
- bodyText: 'same body',
190
- suggestions: [],
191
- },
192
- {
193
- mediaType: 'video',
194
- videoPreviewImg: 'https://example.com/three-thumb.jpg',
195
- bodyText: 'same body',
196
- suggestions: [],
197
- },
198
- ]),
199
- '',
200
- 0,
201
- );
202
-
203
- const cardNodes = getNodesByClassName('message-pop align-left message-pop-carousel rcs-carousel-card');
204
- const keys = cardNodes.map((node) => node.key());
205
-
206
- expect(keys).toEqual([
207
- 'rcs-carousel-0-same body',
208
- 'rcs-carousel-1-same body',
209
- 'rcs-carousel-2-same body',
210
- ]);
211
- expect(new Set(keys).size).toBe(keys.length);
212
- });
213
- });
214
72
  });
@@ -18,7 +18,7 @@ import injectReducer from '../../utils/injectReducer';
18
18
  import injectSaga from '../../utils/injectSaga';
19
19
 
20
20
  import CommonTestAndPreview from '../CommonTestAndPreview';
21
- import { CHANNELS, RCS_SMS_FALLBACK_VAR_MAPPED_PROP } from '../CommonTestAndPreview/constants';
21
+ import { CHANNELS } from '../CommonTestAndPreview/constants';
22
22
  import * as commonTestAndPreviewActions from '../CommonTestAndPreview/actions';
23
23
  import { commonTestAndPreviewSaga } from '../CommonTestAndPreview/sagas';
24
24
  import commonTestAndPreviewReducer from '../CommonTestAndPreview/reducer';
@@ -78,16 +78,6 @@ TestAndPreviewSlidebox.propTypes = {
78
78
  content: PropTypes.string,
79
79
  beeInstance: PropTypes.object,
80
80
  currentTab: PropTypes.number,
81
- smsFallbackContent: PropTypes.shape({
82
- templateContent: PropTypes.string,
83
- senderId: PropTypes.string,
84
- templateName: PropTypes.string,
85
- [RCS_SMS_FALLBACK_VAR_MAPPED_PROP]: PropTypes.object,
86
- }),
87
- /** Passed to CommonTestAndPreview for RCS test-meta resolution (slot semantics vs full-mode). */
88
- rcsTestPreviewOptions: PropTypes.shape({
89
- isLibraryMode: PropTypes.bool,
90
- }),
91
81
  // Redux props are passed through
92
82
  actions: PropTypes.object.isRequired,
93
83
  extractedTags: PropTypes.array.isRequired,
@@ -119,12 +109,10 @@ TestAndPreviewSlidebox.defaultProps = {
119
109
  currentTab: 1,
120
110
  messageMetaConfigId: null,
121
111
  prefilledValues: {},
122
- rcsTestPreviewOptions: undefined,
123
112
  senderDetailsByChannel: {},
124
113
  wecrmAccounts: [],
125
114
  isLoadingSenderDetails: false,
126
115
  orgUnitId: -1,
127
- smsFallbackContent: null,
128
116
  };
129
117
 
130
118
  const mapStateToProps = createStructuredSelector({
@@ -34,7 +34,6 @@ import {
34
34
  GET_PREFILLED_VALUES_SUCCESS,
35
35
  GET_PREFILLED_VALUES_FAILURE,
36
36
  } from './constants';
37
- import { extractPreviewFromLiquidResponse } from '../CommonTestAndPreview/previewApiUtils';
38
37
 
39
38
  // Search Customers Saga
40
39
  export function* searchCustomersSaga(action) {
@@ -81,12 +80,11 @@ export function* updatePreviewSaga(action) {
81
80
  const customValues = action.payload.resolvedTags;
82
81
 
83
82
  const response = yield call(Api.updateEmailPreview, action.payload);
84
- const previewPayload = extractPreviewFromLiquidResponse(response);
85
- if (previewPayload) {
83
+ if (response?.data) {
86
84
  yield put({
87
85
  type: UPDATE_PREVIEW_SUCCESS,
88
86
  payload: {
89
- previewData: previewPayload,
87
+ previewData: response.data,
90
88
  customValues, // Pass custom values to be preserved
91
89
  },
92
90
  });
@@ -223,13 +221,8 @@ export function* createMessageMetaSaga(action) {
223
221
  export function* getPrefilledValuesSaga(action) {
224
222
  try {
225
223
  const response = yield call(Api.updateEmailPreview, action.payload);
226
- const body =
227
- response?.data !== undefined && response?.data !== null
228
- ? response.data
229
- : response;
230
- const resolvedTagValues = body?.resolvedTagValues;
231
- if (resolvedTagValues != null) {
232
- yield put({ type: GET_PREFILLED_VALUES_SUCCESS, payload: { values: resolvedTagValues } });
224
+ if (response?.data) {
225
+ yield put({ type: GET_PREFILLED_VALUES_SUCCESS, payload: { values: response?.data?.resolvedTagValues } });
233
226
  } else {
234
227
  yield put({ type: GET_PREFILLED_VALUES_FAILURE, payload: { error: response.error || 'Failed to fetch prefilled values' } });
235
228
  }
@@ -136,9 +136,7 @@ describe('TestAndPreviewSlidebox Sagas', () => {
136
136
  describe('updatePreviewSaga', () => {
137
137
  it('should handle successful preview update', () => {
138
138
  const mockResponse = {
139
- data: {
140
- resolvedBody: 'Test Preview Data',
141
- },
139
+ data: 'Test Preview Data',
142
140
  };
143
141
  const customValues = { test: 'value' };
144
142
  return expectSaga(sagas.updatePreviewSaga, {