@capillarytech/creatives-library 8.0.239-alpha.0 → 8.0.239

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 (110) hide show
  1. package/package.json +1 -1
  2. package/services/api.js +0 -5
  3. package/translations/en.json +0 -1
  4. package/utils/transformerUtils.js +0 -42
  5. package/v2Components/CapImageUpload/constants.js +0 -2
  6. package/v2Components/CapImageUpload/index.js +14 -54
  7. package/v2Components/CapImageUpload/index.scss +1 -4
  8. package/v2Components/CapImageUpload/messages.js +0 -4
  9. package/v2Containers/App/constants.js +0 -5
  10. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +0 -1
  11. package/v2Containers/CreativesContainer/SlideBoxContent.js +2 -57
  12. package/v2Containers/CreativesContainer/SlideBoxHeader.js +0 -1
  13. package/v2Containers/CreativesContainer/constants.js +0 -2
  14. package/v2Containers/CreativesContainer/index.js +0 -152
  15. package/v2Containers/CreativesContainer/messages.js +0 -4
  16. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +0 -3
  17. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +0 -2
  18. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +0 -25
  19. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +0 -18
  20. package/v2Containers/Rcs/index.js +153 -383
  21. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +0 -46
  22. package/v2Containers/Rcs/tests/index.test.js +168 -0
  23. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +0 -4
  24. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +0 -8
  25. package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
  26. package/v2Containers/Templates/_templates.scss +0 -203
  27. package/v2Containers/Templates/actions.js +1 -2
  28. package/v2Containers/Templates/constants.js +0 -1
  29. package/v2Containers/Templates/index.js +30 -273
  30. package/v2Containers/Templates/messages.js +0 -24
  31. package/v2Containers/Templates/reducer.js +0 -2
  32. package/v2Containers/Templates/tests/index.test.js +0 -10
  33. package/v2Containers/TemplatesV2/index.js +2 -3
  34. package/v2Containers/TemplatesV2/messages.js +0 -4
  35. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +0 -132
  36. package/v2Components/CapImageUrlUpload/constants.js +0 -19
  37. package/v2Components/CapImageUrlUpload/index.js +0 -455
  38. package/v2Components/CapImageUrlUpload/index.scss +0 -35
  39. package/v2Components/CapImageUrlUpload/messages.js +0 -47
  40. package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -175
  41. package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
  42. package/v2Containers/WebPush/Create/components/ButtonList.js +0 -144
  43. package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
  44. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
  45. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
  46. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -633
  47. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
  48. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
  49. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -80
  50. package/v2Containers/WebPush/Create/index.js +0 -1727
  51. package/v2Containers/WebPush/Create/index.scss +0 -123
  52. package/v2Containers/WebPush/Create/messages.js +0 -199
  53. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -241
  54. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -290
  55. package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -81
  56. package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -240
  57. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -23
  58. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -139
  59. package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
  60. package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
  61. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  62. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  63. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
  64. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
  65. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
  66. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
  67. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -44
  68. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -110
  69. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
  70. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -72
  71. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -55
  72. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -70
  73. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -512
  74. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -77
  75. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -527
  76. package/v2Containers/WebPush/Create/preview/constants.js +0 -162
  77. package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -104
  78. package/v2Containers/WebPush/Create/preview/preview.scss +0 -409
  79. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -300
  80. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
  81. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
  82. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
  83. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -303
  84. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
  85. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
  86. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
  87. package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -188
  88. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -106
  89. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
  90. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -75
  91. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -174
  92. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -909
  93. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1077
  94. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
  95. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -943
  96. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -128
  97. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -121
  98. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
  99. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -127
  100. package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -116
  101. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
  102. package/v2Containers/WebPush/actions.js +0 -60
  103. package/v2Containers/WebPush/constants.js +0 -108
  104. package/v2Containers/WebPush/index.js +0 -2
  105. package/v2Containers/WebPush/reducer.js +0 -104
  106. package/v2Containers/WebPush/sagas.js +0 -119
  107. package/v2Containers/WebPush/selectors.js +0 -65
  108. package/v2Containers/WebPush/tests/reducer.test.js +0 -863
  109. package/v2Containers/WebPush/tests/sagas.test.js +0 -566
  110. package/v2Containers/WebPush/tests/selectors.test.js +0 -843
@@ -1,110 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- /**
5
- * AndroidMobileExpanded Component
6
- *
7
- * Renders the expanded state for Android mobile notifications.
8
- * Layout structure:
9
- * - Wrapper (contains all content except arrow):
10
- * - Header: Browser icon | Browser name, URL, timestamp (all inline in same row) | Brand icon
11
- * - Body: Title text (bold) → Body text (limited to 4 lines with ellipsis) → Media image (if visible)
12
- * - Arrow icon (^ ) - sibling to wrapper, aligned to top
13
- */
14
- const AndroidMobileExpanded = ({
15
- icon,
16
- selectedBrowser,
17
- notificationTitle,
18
- notificationBody,
19
- displayUrl,
20
- brandIcon,
21
- shouldShowBrandIcon,
22
- shouldShowBrandIconExpanded,
23
- mediaImageUrl,
24
- }) => {
25
- // Get browser display name
26
- const getBrowserDisplayName = (browser) => {
27
- const browserNames = {
28
- 'Chrome': 'Chrome',
29
- 'Firefox': 'Firefox',
30
- 'Edge': 'Edge',
31
- 'Opera': 'Opera',
32
- };
33
- return browserNames[browser] || browser;
34
- };
35
-
36
- const showBrandIcon = (shouldShowBrandIconExpanded || shouldShowBrandIcon) && brandIcon;
37
-
38
- return (
39
- <>
40
- {/* Browser icon as separate column, aligned to top */}
41
- <div className="android-mobile-expanded-icon">
42
- <div className="notification-icon-container">
43
- <img src={icon} alt={selectedBrowser} className="notification-icon" />
44
- </div>
45
- </div>
46
-
47
- <div className="android-mobile-expanded-wrapper">
48
- {/* Top section: header + title with brand icon column */}
49
- <div className="android-mobile-expanded-top">
50
- <div className="android-mobile-expanded-top-content">
51
- <div className="android-mobile-expanded-header">
52
- <div className="android-mobile-expanded-header-content">
53
- <span className="android-mobile-expanded-browser-name">
54
- {getBrowserDisplayName(selectedBrowser)}
55
- </span>
56
- <span className="android-mobile-expanded-domain-time">
57
- <span className="android-mobile-expanded-domain">{displayUrl}</span>
58
- <span className="android-mobile-expanded-time">2:29 PM</span>
59
- </span>
60
- </div>
61
- </div>
62
-
63
- <div className="android-mobile-expanded-title">{notificationTitle}</div>
64
- </div>
65
-
66
- {showBrandIcon && (
67
- <div className="notification-brand-icon-container android-mobile-chrome-brand-icon">
68
- <img src={brandIcon} alt="Brand icon" className="notification-brand-icon" />
69
- </div>
70
- )}
71
- </div>
72
-
73
- {/* Body container: title, body, media */}
74
- <div className="android-mobile-expanded-body">
75
- {/* Body text (limited to 4 lines) */}
76
- <div className="android-mobile-expanded-body-text">{notificationBody}</div>
77
-
78
- {/* Media image at bottom (if visible) */}
79
- {mediaImageUrl && (
80
- <div className="android-mobile-expanded-media">
81
- <img
82
- src={mediaImageUrl}
83
- alt="Notification media"
84
- className="android-mobile-expanded-media-image"
85
- />
86
- </div>
87
- )}
88
- </div>
89
- </div>
90
-
91
- {/* Arrow icon as sibling to wrapper */}
92
- <div className="notification-action-arrow android-mobile-expanded-arrow">^</div>
93
- </>
94
- );
95
- };
96
-
97
- AndroidMobileExpanded.propTypes = {
98
- icon: PropTypes.string.isRequired,
99
- selectedBrowser: PropTypes.string.isRequired,
100
- notificationTitle: PropTypes.string,
101
- notificationBody: PropTypes.string,
102
- displayUrl: PropTypes.string,
103
- brandIcon: PropTypes.string,
104
- shouldShowBrandIcon: PropTypes.bool,
105
- shouldShowBrandIconExpanded: PropTypes.bool,
106
- mediaImageUrl: PropTypes.string,
107
- };
108
-
109
- export default AndroidMobileExpanded;
110
-
@@ -1,45 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- /**
5
- * iOS/iPadOS Notification Header Component
6
- *
7
- * Displays a simple notification header for iOS and iPadOS devices.
8
- * Layout: Browser icon | Title "now" | Body text
9
- *
10
- * Note: iOS/iPadOS notifications do NOT show:
11
- * - Brand icon
12
- * - URL/domain
13
- * - CTA buttons
14
- * - Media images
15
- * - Expanded state
16
- */
17
- const IOSHeader = ({
18
- icon,
19
- selectedBrowser,
20
- notificationTitle,
21
- notificationBody,
22
- }) => (
23
- <div className="notification-header ios-header">
24
- <div className="notification-icon-container">
25
- <img src={icon} alt={selectedBrowser} className="notification-icon" />
26
- </div>
27
- <div className="notification-content ios-content">
28
- <div className="notification-title-row">
29
- <div className="notification-title">{notificationTitle}</div>
30
- <div className="notification-time">now</div>
31
- </div>
32
- <div className="notification-body">{notificationBody}</div>
33
- </div>
34
- </div>
35
- );
36
-
37
- IOSHeader.propTypes = {
38
- icon: PropTypes.string.isRequired,
39
- selectedBrowser: PropTypes.string.isRequired,
40
- notificationTitle: PropTypes.string,
41
- notificationBody: PropTypes.string,
42
- };
43
-
44
- export default IOSHeader;
45
-
@@ -1,72 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- const NotificationExpandedContent = ({
5
- shouldRenderExpandedMedia,
6
- shouldShowBrandIconInExpandedMac,
7
- brandIcon,
8
- mediaImageUrl,
9
- enableCtas,
10
- ctaButtons,
11
- }) => (
12
- <div className="notification-expanded-content">
13
- {shouldRenderExpandedMedia && (
14
- <div className="notification-media">
15
- {shouldShowBrandIconInExpandedMac ? (
16
- <img
17
- src={brandIcon}
18
- alt="Brand icon"
19
- className="notification-media-image"
20
- />
21
- ) : (
22
- mediaImageUrl && (
23
- <img
24
- src={mediaImageUrl}
25
- alt="Notification media"
26
- className="notification-media-image"
27
- />
28
- )
29
- )}
30
- </div>
31
- )}
32
-
33
- {enableCtas && ctaButtons && ctaButtons.length > 0 && (
34
- <div className="notification-actions">
35
- {ctaButtons.map((button) => (
36
- <div key={button.id} className="notification-action-item">
37
- <div className="notification-action-divider"></div>
38
- <button
39
- type="button"
40
- className="notification-action-button"
41
- >
42
- {button.icon && (
43
- <span className="notification-action-icon">{button.icon}</span>
44
- )}
45
- <span className="notification-action-label">{button.label}</span>
46
- </button>
47
- </div>
48
- ))}
49
- {/* Note: OS/Browser adds a "Settings" or "Unsubscribe" button from its side */}
50
- {/* This could be included later if needed for more accurate preview */}
51
- </div>
52
- )}
53
- </div>
54
- );
55
-
56
- NotificationExpandedContent.propTypes = {
57
- shouldRenderExpandedMedia: PropTypes.bool,
58
- shouldShowBrandIconInExpandedMac: PropTypes.bool,
59
- brandIcon: PropTypes.string,
60
- mediaImageUrl: PropTypes.string,
61
- enableCtas: PropTypes.bool,
62
- ctaButtons: PropTypes.arrayOf(
63
- PropTypes.shape({
64
- id: PropTypes.string.isRequired,
65
- label: PropTypes.string,
66
- icon: PropTypes.string,
67
- })
68
- ),
69
- };
70
-
71
- export default NotificationExpandedContent;
72
-
@@ -1,55 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- const NotificationHeader = ({
5
- icon,
6
- selectedBrowser,
7
- notificationTitle,
8
- displayUrl,
9
- notificationBody,
10
- shouldShowBrandIcon,
11
- brandIcon,
12
- isExpanded,
13
- }) => (
14
- <div className="notification-header">
15
- {/* Left rail: browser icon */}
16
- <div className="notification-icon-container">
17
- <img src={icon} alt={selectedBrowser} className="notification-icon" />
18
- </div>
19
-
20
- {/* Center rail: notification text (title, url, body) */}
21
- <div className="notification-content">
22
- <div className="notification-title">{notificationTitle}</div>
23
- <div className="notification-url">{displayUrl}</div>
24
- <div className="notification-body">{notificationBody}</div>
25
- </div>
26
-
27
- {/* Right rail: optional brand icon (macOS + Chrome, collapsed only) */}
28
- {shouldShowBrandIcon && (
29
- <div className="notification-brand-icon-container">
30
- <img src={brandIcon} alt="Brand icon" className="notification-brand-icon" />
31
- </div>
32
- )}
33
- {/* Menu and expand/collapse icons - shown in macOS + Chrome expanded notification */}
34
- {isExpanded && (
35
- <div className="notification-header-actions">
36
- <div className="notification-action-menu">⋯</div>
37
- <div className="notification-action-arrow">⌄</div>
38
- </div>
39
- )}
40
- </div>
41
- );
42
-
43
- NotificationHeader.propTypes = {
44
- icon: PropTypes.string.isRequired,
45
- selectedBrowser: PropTypes.string.isRequired,
46
- notificationTitle: PropTypes.string,
47
- displayUrl: PropTypes.string,
48
- notificationBody: PropTypes.string,
49
- shouldShowBrandIcon: PropTypes.bool,
50
- brandIcon: PropTypes.string,
51
- isExpanded: PropTypes.bool,
52
- };
53
-
54
- export default NotificationHeader;
55
-
@@ -1,70 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- const WindowsChromeExpanded = ({
5
- icon,
6
- brandIcon,
7
- enableBrandIconPreview,
8
- notificationTitle,
9
- notificationBody,
10
- displayUrl,
11
- browserName = 'Google Chrome',
12
- mediaImageUrl = '',
13
- }) => (
14
- <div className="windows-chrome-expanded-wrapper">
15
- {mediaImageUrl && (
16
- <div className="windows-chrome-banner">
17
- <img
18
- src={mediaImageUrl}
19
- alt="Notification banner"
20
- className="windows-chrome-banner-image"
21
- />
22
- </div>
23
- )}
24
-
25
- <div className="windows-chrome-body">
26
- <div className="windows-chrome-header-row">
27
- <div className="notification-icon-container windows-chrome-browser-icon">
28
- {/* Inline style kept: Ensures browser icon img fills container; SCSS only styles container, not img element */}
29
- <img src={icon} alt="Chrome browser" className="notification-icon" style={{ width: '100%', height: '100%' }} />
30
- </div>
31
- <div className="windows-chrome-browser-title">{browserName}</div>
32
- <div className="windows-chrome-header-actions">
33
- <span className="windows-chrome-menu-text">...</span>
34
- <span className="windows-chrome-close-text">x</span>
35
- </div>
36
- </div>
37
-
38
- <div className="windows-chrome-content-row">
39
- {enableBrandIconPreview && Boolean(brandIcon) && (
40
- <div className="notification-brand-icon-container windows-chrome-brand-icon">
41
- <img
42
- src={brandIcon}
43
- alt="Brand icon"
44
- className="notification-brand-icon"
45
- />
46
- </div>
47
- )}
48
- <div className="windows-chrome-text-block">
49
- <div className="windows-chrome-title">{notificationTitle}</div>
50
- <div className="windows-chrome-body-text">{notificationBody}</div>
51
- <div className="windows-chrome-url">{displayUrl}</div>
52
- </div>
53
- </div>
54
- </div>
55
- </div>
56
- );
57
-
58
- WindowsChromeExpanded.propTypes = {
59
- icon: PropTypes.string.isRequired,
60
- brandIcon: PropTypes.string,
61
- enableBrandIconPreview: PropTypes.bool,
62
- notificationTitle: PropTypes.string,
63
- notificationBody: PropTypes.string,
64
- displayUrl: PropTypes.string,
65
- browserName: PropTypes.string,
66
- mediaImageUrl: PropTypes.string,
67
- };
68
-
69
- export default WindowsChromeExpanded;
70
-