@capillarytech/creatives-library 8.0.359-alpha.0 → 8.0.359-alpha.1

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 (147) hide show
  1. package/constants/unified.js +29 -0
  2. package/index.html +1 -0
  3. package/package.json +1 -1
  4. package/services/tests/api.test.js +35 -20
  5. package/utils/cdnTransformation.js +75 -3
  6. package/utils/commonUtils.js +19 -1
  7. package/utils/rcsPayloadUtils.js +92 -0
  8. package/utils/templateVarUtils.js +201 -0
  9. package/utils/tests/cdnTransformation.test.js +127 -0
  10. package/utils/tests/rcsPayloadUtils.test.js +226 -0
  11. package/utils/tests/templateVarUtils.test.js +204 -0
  12. package/v2Components/CapActionButton/constants.js +7 -0
  13. package/v2Components/CapActionButton/index.js +166 -108
  14. package/v2Components/CapActionButton/index.scss +157 -6
  15. package/v2Components/CapActionButton/messages.js +19 -3
  16. package/v2Components/CapActionButton/tests/index.test.js +41 -17
  17. package/v2Components/CapImageUpload/index.js +2 -2
  18. package/v2Components/CapTagList/index.js +10 -0
  19. package/v2Components/CommonTestAndPreview/CustomValuesEditor.js +72 -49
  20. package/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +8 -2
  21. package/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +214 -21
  22. package/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +16 -0
  23. package/v2Components/CommonTestAndPreview/DeliverySettings/index.js +83 -9
  24. package/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +30 -0
  25. package/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +79 -11
  26. package/v2Components/CommonTestAndPreview/SendTestMessage.js +10 -5
  27. package/v2Components/CommonTestAndPreview/UnifiedPreview/PreviewHeader.js +16 -0
  28. package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js +157 -15
  29. package/v2Components/CommonTestAndPreview/UnifiedPreview/ViberPreviewContent.js +14 -132
  30. package/v2Components/CommonTestAndPreview/UnifiedPreview/WebPushPreviewContent.js +169 -0
  31. package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +400 -239
  32. package/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +202 -10
  33. package/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +11 -0
  34. package/v2Components/CommonTestAndPreview/constants.js +40 -2
  35. package/v2Components/CommonTestAndPreview/index.js +887 -453
  36. package/v2Components/CommonTestAndPreview/messages.js +45 -3
  37. package/v2Components/CommonTestAndPreview/previewApiUtils.js +59 -0
  38. package/v2Components/CommonTestAndPreview/sagas.js +25 -6
  39. package/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +308 -284
  40. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +231 -65
  41. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +118 -5
  42. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +341 -0
  43. package/v2Components/CommonTestAndPreview/tests/PreviewSection.test.js +8 -1
  44. package/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +34 -13
  45. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/PreviewHeader.test.js +163 -0
  46. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/RcsPreviewContent.test.js +281 -283
  47. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/ViberPreviewContent.test.js +0 -364
  48. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/WebPushPreviewContent.test.js +522 -0
  49. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +454 -1
  50. package/v2Components/CommonTestAndPreview/tests/constants.test.js +2 -1
  51. package/v2Components/CommonTestAndPreview/tests/index.test.js +327 -4
  52. package/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +67 -0
  53. package/v2Components/CommonTestAndPreview/tests/sagas.test.js +31 -24
  54. package/v2Components/FormBuilder/index.js +167 -56
  55. package/v2Components/SmsFallback/SmsFallbackLocalSelector.js +91 -0
  56. package/v2Components/SmsFallback/constants.js +73 -0
  57. package/v2Components/SmsFallback/index.js +956 -0
  58. package/v2Components/SmsFallback/index.scss +265 -0
  59. package/v2Components/SmsFallback/messages.js +78 -0
  60. package/v2Components/SmsFallback/smsFallbackUtils.js +119 -0
  61. package/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +50 -0
  62. package/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +147 -0
  63. package/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +304 -0
  64. package/v2Components/SmsFallback/tests/smsFallbackUi.test.js +223 -0
  65. package/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +309 -0
  66. package/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +422 -0
  67. package/v2Components/SmsFallback/useLocalTemplateList.js +92 -0
  68. package/v2Components/TemplatePreview/_templatePreview.scss +37 -22
  69. package/v2Components/TemplatePreview/constants.js +2 -0
  70. package/v2Components/TemplatePreview/index.js +143 -31
  71. package/v2Components/TemplatePreview/tests/index.test.js +142 -0
  72. package/v2Components/TestAndPreviewSlidebox/index.js +15 -3
  73. package/v2Components/TestAndPreviewSlidebox/sagas.js +11 -4
  74. package/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +3 -1
  75. package/v2Components/VarSegmentMessageEditor/constants.js +2 -0
  76. package/v2Components/VarSegmentMessageEditor/index.js +125 -0
  77. package/v2Components/VarSegmentMessageEditor/index.scss +46 -0
  78. package/v2Containers/App/constants.js +3 -0
  79. package/v2Containers/App/tests/constants.test.js +61 -0
  80. package/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +17 -0
  81. package/v2Containers/CreativesContainer/SlideBoxContent.js +36 -4
  82. package/v2Containers/CreativesContainer/SlideBoxFooter.js +14 -5
  83. package/v2Containers/CreativesContainer/SlideBoxHeader.js +36 -5
  84. package/v2Containers/CreativesContainer/constants.js +9 -0
  85. package/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +79 -0
  86. package/v2Containers/CreativesContainer/index.js +382 -127
  87. package/v2Containers/CreativesContainer/index.scss +83 -1
  88. package/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +90 -0
  89. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +79 -34
  90. package/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +79 -16
  91. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +8 -0
  92. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +357 -98
  93. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +20 -15
  94. package/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +258 -0
  95. package/v2Containers/CreativesContainer/tests/index.test.js +71 -9
  96. package/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +125 -0
  97. package/v2Containers/MobilePush/Create/test/saga.test.js +2 -2
  98. package/v2Containers/Rcs/constants.js +120 -11
  99. package/v2Containers/Rcs/index.js +2577 -812
  100. package/v2Containers/Rcs/index.scss +281 -8
  101. package/v2Containers/Rcs/messages.js +34 -3
  102. package/v2Containers/Rcs/rcsLibraryHydrationUtils.js +225 -0
  103. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +98036 -70145
  104. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +0 -5
  105. package/v2Containers/Rcs/tests/index.test.js +152 -121
  106. package/v2Containers/Rcs/tests/mockData.js +38 -0
  107. package/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +318 -0
  108. package/v2Containers/Rcs/tests/utils.test.js +646 -30
  109. package/v2Containers/Rcs/utils.js +478 -11
  110. package/v2Containers/Sms/Create/index.js +106 -40
  111. package/v2Containers/Sms/smsFormDataHelpers.js +67 -0
  112. package/v2Containers/Sms/tests/smsFormDataHelpers.test.js +253 -0
  113. package/v2Containers/SmsTrai/Create/index.js +9 -4
  114. package/v2Containers/SmsTrai/Edit/constants.js +2 -0
  115. package/v2Containers/SmsTrai/Edit/index.js +640 -130
  116. package/v2Containers/SmsTrai/Edit/index.scss +121 -0
  117. package/v2Containers/SmsTrai/Edit/messages.js +14 -4
  118. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4328 -2375
  119. package/v2Containers/SmsWrapper/index.js +37 -8
  120. package/v2Containers/TagList/index.js +6 -0
  121. package/v2Containers/Templates/TemplatesActionBar.js +101 -0
  122. package/v2Containers/Templates/_templates.scss +166 -86
  123. package/v2Containers/Templates/actions.js +11 -0
  124. package/v2Containers/Templates/constants.js +2 -0
  125. package/v2Containers/Templates/index.js +203 -145
  126. package/v2Containers/Templates/sagas.js +62 -13
  127. package/v2Containers/Templates/tests/TemplatesActionBar.test.js +120 -0
  128. package/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1062 -1017
  129. package/v2Containers/Templates/tests/sagas.test.js +222 -22
  130. package/v2Containers/Templates/tests/smsTemplatesListApi.test.js +180 -0
  131. package/v2Containers/Templates/tests/webpush.test.js +375 -0
  132. package/v2Containers/Templates/utils/smsTemplatesListApi.js +79 -0
  133. package/v2Containers/TemplatesV2/TemplatesV2.style.js +72 -1
  134. package/v2Containers/TemplatesV2/index.js +86 -23
  135. package/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +131 -0
  136. package/v2Containers/Viber/constants.js +0 -19
  137. package/v2Containers/Viber/index.js +47 -714
  138. package/v2Containers/Viber/index.scss +0 -148
  139. package/v2Containers/Viber/messages.js +0 -116
  140. package/v2Containers/Viber/tests/index.test.js +0 -80
  141. package/v2Containers/WeChat/MapTemplates/test/saga.test.js +9 -9
  142. package/v2Containers/WebPush/Create/index.js +91 -8
  143. package/v2Containers/WebPush/Create/index.scss +7 -0
  144. package/v2Containers/WebPush/Create/tests/getTemplateContent.test.js +348 -0
  145. package/v2Containers/WebPush/Create/tests/testAndPreviewIntegration.test.js +325 -0
  146. package/v2Containers/Whatsapp/index.js +3 -20
  147. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +578 -34
@@ -200,370 +200,6 @@ describe('ViberPreviewContent', () => {
200
200
 
201
201
  expect(screen.getByText('Click Here')).toBeTruthy();
202
202
  });
203
-
204
- it('should not render button when buttonText has only whitespace', () => {
205
- const props = {
206
- ...defaultProps,
207
- content: {
208
- viberPreviewContent: {
209
- messageContent: 'Message',
210
- buttonText: ' ',
211
- },
212
- },
213
- };
214
-
215
- const { container } = render(
216
- <TestWrapper>
217
- <ComponentToRender {...props} />
218
- </TestWrapper>
219
- );
220
-
221
- expect(container.querySelector('.viber-button-base')).toBeFalsy();
222
- });
223
- });
224
-
225
- describe('Carousel Content', () => {
226
- it('should render no content when carousel is selected but cards are empty', () => {
227
- const props = {
228
- ...defaultProps,
229
- content: {
230
- viberPreviewContent: {
231
- type: 'CAROUSEL',
232
- cards: [
233
- {
234
- text: '',
235
- mediaUrl: '',
236
- buttons: [
237
- { title: '', action: '' },
238
- ],
239
- },
240
- {
241
- text: ' ',
242
- mediaUrl: ' ',
243
- buttons: [
244
- { title: ' ', action: 'https://example.com/2' },
245
- ],
246
- },
247
- ],
248
- },
249
- },
250
- };
251
-
252
- render(
253
- <TestWrapper>
254
- <ComponentToRender {...props} />
255
- </TestWrapper>
256
- );
257
-
258
- expect(screen.getByText('No content available')).toBeTruthy();
259
- });
260
-
261
- it('should render carousel cards when type is CAROUSEL', () => {
262
- const props = {
263
- ...defaultProps,
264
- content: {
265
- viberPreviewContent: {
266
- type: 'CAROUSEL',
267
- cards: [
268
- {
269
- text: 'Card 1 text',
270
- mediaUrl: 'https://image.url/card1.jpg',
271
- buttons: [
272
- { title: 'Button 1', action: 'https://example.com/1' },
273
- ],
274
- },
275
- {
276
- text: 'Card 2 text',
277
- mediaUrl: 'https://image.url/card2.jpg',
278
- buttons: [
279
- { title: 'Button 2', action: 'https://example.com/2' },
280
- ],
281
- },
282
- ],
283
- },
284
- },
285
- };
286
-
287
- render(
288
- <TestWrapper>
289
- <ComponentToRender {...props} />
290
- </TestWrapper>
291
- );
292
-
293
- expect(screen.getByText('Card 1 text')).toBeTruthy();
294
- expect(screen.getByText('Card 2 text')).toBeTruthy();
295
- expect(screen.getByText('Button 1')).toBeTruthy();
296
- expect(screen.getByText('Button 2')).toBeTruthy();
297
- });
298
-
299
- it('should not render empty carousel button placeholder', () => {
300
- const props = {
301
- ...defaultProps,
302
- content: {
303
- viberPreviewContent: {
304
- type: 'CAROUSEL',
305
- cards: [
306
- {
307
- text: 'Card 1 text',
308
- mediaUrl: 'https://image.url/card1.jpg',
309
- buttons: [
310
- { title: '', action: 'https://example.com/1' },
311
- { title: ' ', action: 'https://example.com/2' },
312
- ],
313
- },
314
- ],
315
- },
316
- },
317
- };
318
-
319
- const { container } = render(
320
- <TestWrapper>
321
- <ComponentToRender {...props} />
322
- </TestWrapper>
323
- );
324
-
325
- expect(container.querySelector('.viber-carousel-preview-button')).toBeNull();
326
- });
327
-
328
- it('should show carousel shell when showCarouselEditorPreview is true even if cards are empty', () => {
329
- const props = {
330
- ...defaultProps,
331
- content: {
332
- viberPreviewContent: {
333
- type: 'CAROUSEL',
334
- showCarouselEditorPreview: true,
335
- cards: [
336
- { text: '', mediaUrl: '', buttons: [{ title: '', action: '' }] },
337
- { text: '', mediaUrl: '', buttons: [{ title: '', action: '' }] },
338
- ],
339
- },
340
- },
341
- };
342
-
343
- const { container } = render(
344
- <TestWrapper>
345
- <ComponentToRender {...props} />
346
- </TestWrapper>
347
- );
348
-
349
- expect(screen.queryByText('No content available')).toBeNull();
350
- expect(container.querySelector('.viber-carousel-preview-scroll')).toBeTruthy();
351
- expect(container.querySelector('.viber-carousel-message-box-placeholder')).toBeTruthy();
352
- });
353
-
354
- it('should render carousel message text in message box when type is CAROUSEL', () => {
355
- const props = {
356
- ...defaultProps,
357
- content: {
358
- viberPreviewContent: {
359
- type: 'CAROUSEL',
360
- messageContent: 'Carousel intro copy',
361
- cards: [
362
- {
363
- text: 'Card text',
364
- mediaUrl: 'https://image.url/c.jpg',
365
- buttons: [{ title: 'Go', action: 'https://example.com' }],
366
- },
367
- ],
368
- },
369
- },
370
- };
371
-
372
- const { container } = render(
373
- <TestWrapper>
374
- <ComponentToRender {...props} />
375
- </TestWrapper>
376
- );
377
-
378
- expect(container.querySelector('.viber-carousel-message-box-text')).toHaveTextContent('Carousel intro copy');
379
- expect(screen.queryByText('Carousel intro copy')).toBeTruthy();
380
- });
381
-
382
- it('should hide account icon when carousel is shown', () => {
383
- const props = {
384
- ...defaultProps,
385
- content: {
386
- viberPreviewContent: {
387
- type: 'CAROUSEL',
388
- cards: [
389
- {
390
- text: 'Carousel card line',
391
- mediaUrl: '',
392
- buttons: [{ title: 'Open link', action: 'https://x.com' }],
393
- },
394
- ],
395
- },
396
- },
397
- };
398
-
399
- const { container } = render(
400
- <TestWrapper>
401
- <ComponentToRender {...props} />
402
- </TestWrapper>
403
- );
404
-
405
- expect(container.querySelector('.viber-account-icon')).toBeNull();
406
- });
407
-
408
- it('should use image placeholder when carousel card mediaUrl is whitespace only', () => {
409
- const props = {
410
- ...defaultProps,
411
- content: {
412
- viberPreviewContent: {
413
- type: 'CAROUSEL',
414
- cards: [
415
- {
416
- text: 'Only text',
417
- mediaUrl: ' ',
418
- buttons: [{ title: 'Btn', action: 'https://example.com' }],
419
- },
420
- ],
421
- },
422
- },
423
- };
424
-
425
- const { container } = render(
426
- <TestWrapper>
427
- <ComponentToRender {...props} />
428
- </TestWrapper>
429
- );
430
-
431
- expect(container.querySelector('.viber-carousel-preview-image-placeholder')).toBeTruthy();
432
- expect(container.querySelector('.viber-carousel-preview-image')).toBeNull();
433
- });
434
-
435
- it('should render at most two carousel buttons per card', () => {
436
- const props = {
437
- ...defaultProps,
438
- content: {
439
- viberPreviewContent: {
440
- type: 'CAROUSEL',
441
- cards: [
442
- {
443
- text: 'Card',
444
- mediaUrl: 'https://image.url/c.jpg',
445
- buttons: [
446
- { title: 'One', action: 'https://a.com' },
447
- { title: 'Two', action: 'https://b.com' },
448
- { title: 'Three', action: 'https://c.com' },
449
- ],
450
- },
451
- ],
452
- },
453
- },
454
- };
455
-
456
- const { container } = render(
457
- <TestWrapper>
458
- <ComponentToRender {...props} />
459
- </TestWrapper>
460
- );
461
-
462
- expect(container.querySelectorAll('.viber-carousel-preview-button')).toHaveLength(2);
463
- expect(screen.getByText('One')).toBeTruthy();
464
- expect(screen.getByText('Two')).toBeTruthy();
465
- expect(screen.queryByText('Three')).toBeNull();
466
- });
467
-
468
- it('should apply secondary class to second carousel button', () => {
469
- const props = {
470
- ...defaultProps,
471
- content: {
472
- viberPreviewContent: {
473
- type: 'CAROUSEL',
474
- cards: [
475
- {
476
- text: 'Card',
477
- mediaUrl: 'https://image.url/c.jpg',
478
- buttons: [
479
- { title: 'Primary', action: 'https://a.com' },
480
- { title: 'Secondary', action: 'https://b.com' },
481
- ],
482
- },
483
- ],
484
- },
485
- },
486
- };
487
-
488
- const { container } = render(
489
- <TestWrapper>
490
- <ComponentToRender {...props} />
491
- </TestWrapper>
492
- );
493
-
494
- const buttons = container.querySelectorAll('.viber-carousel-preview-button');
495
- expect(buttons[0].className).toContain('viber-carousel-preview-button');
496
- expect(buttons[0].className).not.toContain('viber-carousel-preview-button-secondary');
497
- expect(buttons[1].className).toContain('viber-carousel-preview-button-secondary');
498
- });
499
-
500
- it('should show carousel when only a button title is present on a card', () => {
501
- const props = {
502
- ...defaultProps,
503
- content: {
504
- viberPreviewContent: {
505
- type: 'CAROUSEL',
506
- cards: [
507
- {
508
- text: '',
509
- mediaUrl: '',
510
- buttons: [{ title: 'Tap me', action: 'https://example.com' }],
511
- },
512
- ],
513
- },
514
- },
515
- };
516
-
517
- render(
518
- <TestWrapper>
519
- <ComponentToRender {...props} />
520
- </TestWrapper>
521
- );
522
-
523
- expect(screen.getByText('Tap me')).toBeTruthy();
524
- expect(screen.queryByText('No content available')).toBeNull();
525
- });
526
-
527
- it('should show one placeholder card when editor preview and cards array is empty', () => {
528
- const props = {
529
- ...defaultProps,
530
- content: {
531
- viberPreviewContent: {
532
- type: 'CAROUSEL',
533
- showCarouselEditorPreview: true,
534
- cards: [],
535
- },
536
- },
537
- };
538
-
539
- const { container } = render(
540
- <TestWrapper>
541
- <ComponentToRender {...props} />
542
- </TestWrapper>
543
- );
544
-
545
- expect(container.querySelectorAll('.viber-carousel-preview-card')).toHaveLength(1);
546
- });
547
-
548
- it('should show no content when CAROUSEL has empty cards and no editor preview flag', () => {
549
- const props = {
550
- ...defaultProps,
551
- content: {
552
- viberPreviewContent: {
553
- type: 'CAROUSEL',
554
- cards: [],
555
- },
556
- },
557
- };
558
-
559
- render(
560
- <TestWrapper>
561
- <ComponentToRender {...props} />
562
- </TestWrapper>
563
- );
564
-
565
- expect(screen.getByText('No content available')).toBeTruthy();
566
- });
567
203
  });
568
204
 
569
205
  describe('Account and Brand Name', () => {