@capillarytech/creatives-library 8.0.242-alpha.0 → 8.0.242-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 (215) hide show
  1. package/assets/Android.png +0 -0
  2. package/assets/iOS.png +0 -0
  3. package/constants/unified.js +2 -1
  4. package/initialReducer.js +2 -0
  5. package/package.json +1 -1
  6. package/sagas/__tests__/assetPolling.test.js +74 -3
  7. package/sagas/assetPolling.js +8 -1
  8. package/services/api.js +10 -5
  9. package/services/tests/api.test.js +18 -0
  10. package/translations/en.json +0 -1
  11. package/utils/common.js +5 -0
  12. package/utils/commonUtils.js +14 -1
  13. package/utils/tests/commonUtil.test.js +224 -0
  14. package/utils/transformTemplateConfig.js +0 -10
  15. package/utils/transformerUtils.js +0 -42
  16. package/v2Components/CapDeviceContent/index.js +61 -56
  17. package/v2Components/CapImageUpload/constants.js +0 -2
  18. package/v2Components/CapImageUpload/index.js +14 -54
  19. package/v2Components/CapImageUpload/index.scss +1 -4
  20. package/v2Components/CapImageUpload/messages.js +0 -4
  21. package/v2Components/CapTagList/index.js +6 -1
  22. package/v2Components/CapTagListWithInput/index.js +5 -1
  23. package/v2Components/CapTagListWithInput/messages.js +1 -1
  24. package/v2Components/CapWhatsappCTA/tests/index.test.js +5 -0
  25. package/v2Components/ErrorInfoNote/index.js +412 -72
  26. package/v2Components/ErrorInfoNote/messages.js +22 -0
  27. package/v2Components/ErrorInfoNote/style.scss +279 -2
  28. package/v2Components/HtmlEditor/HTMLEditor.js +210 -89
  29. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +1132 -133
  30. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +17 -12
  31. package/v2Components/HtmlEditor/_htmlEditor.scss +8 -23
  32. package/v2Components/HtmlEditor/_index.lazy.scss +1 -1
  33. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +13 -101
  34. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +148 -139
  35. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +2 -1
  36. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  37. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +1 -1
  38. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +1 -0
  39. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +4 -7
  40. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +35 -45
  41. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +1 -3
  42. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +7 -6
  44. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +3 -6
  45. package/v2Components/HtmlEditor/components/PreviewPane/index.js +10 -11
  46. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  47. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +87 -62
  48. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +49 -31
  49. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +254 -0
  50. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +362 -0
  51. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +51 -0
  52. package/v2Components/HtmlEditor/constants.js +29 -20
  53. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +373 -16
  54. package/v2Components/HtmlEditor/hooks/useEditorContent.js +5 -2
  55. package/v2Components/HtmlEditor/hooks/useInAppContent.js +88 -146
  56. package/v2Components/HtmlEditor/index.js +1 -1
  57. package/v2Components/HtmlEditor/messages.js +95 -85
  58. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +99 -101
  59. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +23 -25
  60. package/v2Components/HtmlEditor/utils/validationAdapter.js +34 -41
  61. package/v2Components/MobilePushPreviewV2/index.js +32 -7
  62. package/v2Components/TemplatePreview/_templatePreview.scss +44 -24
  63. package/v2Components/TemplatePreview/index.js +47 -32
  64. package/v2Components/TemplatePreview/messages.js +4 -0
  65. package/v2Components/TestAndPreviewSlidebox/index.js +31 -25
  66. package/v2Containers/App/constants.js +0 -5
  67. package/v2Containers/BeeEditor/index.js +82 -80
  68. package/v2Containers/BeePopupEditor/constants.js +10 -0
  69. package/v2Containers/BeePopupEditor/index.js +193 -0
  70. package/v2Containers/BeePopupEditor/tests/index.test.js +627 -0
  71. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +0 -1
  72. package/v2Containers/CreativesContainer/SlideBoxContent.js +148 -120
  73. package/v2Containers/CreativesContainer/SlideBoxFooter.js +9 -3
  74. package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
  75. package/v2Containers/CreativesContainer/constants.js +1 -2
  76. package/v2Containers/CreativesContainer/index.js +173 -193
  77. package/v2Containers/CreativesContainer/messages.js +4 -4
  78. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +38 -50
  79. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +36 -0
  80. package/v2Containers/Email/actions.js +7 -0
  81. package/v2Containers/Email/constants.js +5 -1
  82. package/v2Containers/Email/index.js +13 -0
  83. package/v2Containers/Email/messages.js +32 -0
  84. package/v2Containers/Email/reducer.js +12 -1
  85. package/v2Containers/Email/sagas.js +41 -6
  86. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +2 -0
  87. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +1045 -0
  88. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +193 -7
  89. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +40 -74
  90. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +2 -67
  91. package/v2Containers/EmailWrapper/constants.js +2 -0
  92. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +436 -67
  93. package/v2Containers/EmailWrapper/index.js +99 -23
  94. package/v2Containers/EmailWrapper/messages.js +61 -1
  95. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +26 -1
  96. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +111 -77
  97. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +376 -0
  98. package/v2Containers/InApp/__tests__/sagas.test.js +363 -0
  99. package/v2Containers/InApp/actions.js +7 -0
  100. package/v2Containers/InApp/constants.js +20 -4
  101. package/v2Containers/InApp/index.js +800 -357
  102. package/v2Containers/InApp/index.scss +4 -3
  103. package/v2Containers/InApp/messages.js +7 -3
  104. package/v2Containers/InApp/reducer.js +21 -3
  105. package/v2Containers/InApp/sagas.js +29 -9
  106. package/v2Containers/InApp/selectors.js +25 -5
  107. package/v2Containers/InApp/tests/index.test.js +154 -50
  108. package/v2Containers/InApp/tests/reducer.test.js +34 -0
  109. package/v2Containers/InApp/tests/sagas.test.js +61 -9
  110. package/v2Containers/InApp/tests/selectors.test.js +612 -0
  111. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +162 -0
  112. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +267 -0
  113. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +9 -0
  114. package/v2Containers/InAppWrapper/constants.js +16 -0
  115. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +473 -0
  116. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +198 -0
  117. package/v2Containers/InAppWrapper/index.js +148 -0
  118. package/v2Containers/InAppWrapper/messages.js +49 -0
  119. package/v2Containers/InappAdvance/index.js +1099 -0
  120. package/v2Containers/InappAdvance/index.scss +10 -0
  121. package/v2Containers/InappAdvance/tests/index.test.js +448 -0
  122. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +3 -3
  123. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +2 -2
  124. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +2 -25
  125. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +9 -18
  126. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +12 -46
  127. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +0 -4
  128. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4 -8
  129. package/v2Containers/TagList/index.js +67 -1
  130. package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
  131. package/v2Containers/Templates/_templates.scss +56 -200
  132. package/v2Containers/Templates/actions.js +1 -2
  133. package/v2Containers/Templates/constants.js +0 -1
  134. package/v2Containers/Templates/index.js +124 -277
  135. package/v2Containers/Templates/messages.js +4 -24
  136. package/v2Containers/Templates/reducer.js +0 -2
  137. package/v2Containers/Templates/tests/index.test.js +0 -10
  138. package/v2Containers/TemplatesV2/index.js +2 -3
  139. package/v2Containers/TemplatesV2/messages.js +0 -4
  140. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +35 -132
  141. package/v2Components/CapImageUrlUpload/constants.js +0 -19
  142. package/v2Components/CapImageUrlUpload/index.js +0 -455
  143. package/v2Components/CapImageUrlUpload/index.scss +0 -35
  144. package/v2Components/CapImageUrlUpload/messages.js +0 -47
  145. package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -175
  146. package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
  147. package/v2Containers/WebPush/Create/components/ButtonList.js +0 -144
  148. package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
  149. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
  150. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
  151. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -633
  152. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
  153. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
  154. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -80
  155. package/v2Containers/WebPush/Create/index.js +0 -1755
  156. package/v2Containers/WebPush/Create/index.scss +0 -123
  157. package/v2Containers/WebPush/Create/messages.js +0 -199
  158. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -241
  159. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -290
  160. package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -81
  161. package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -240
  162. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -23
  163. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -144
  164. package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
  165. package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
  166. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  167. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  168. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
  169. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
  170. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
  171. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
  172. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -44
  173. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -110
  174. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
  175. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -72
  176. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -55
  177. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -70
  178. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -512
  179. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -77
  180. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -527
  181. package/v2Containers/WebPush/Create/preview/constants.js +0 -162
  182. package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -104
  183. package/v2Containers/WebPush/Create/preview/preview.scss +0 -409
  184. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -300
  185. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
  186. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
  187. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
  188. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -303
  189. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
  190. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
  191. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
  192. package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -188
  193. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -106
  194. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
  195. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -75
  196. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -174
  197. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -909
  198. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1077
  199. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
  200. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -943
  201. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -128
  202. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -121
  203. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
  204. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -127
  205. package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -116
  206. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
  207. package/v2Containers/WebPush/actions.js +0 -60
  208. package/v2Containers/WebPush/constants.js +0 -108
  209. package/v2Containers/WebPush/index.js +0 -2
  210. package/v2Containers/WebPush/reducer.js +0 -104
  211. package/v2Containers/WebPush/sagas.js +0 -119
  212. package/v2Containers/WebPush/selectors.js +0 -65
  213. package/v2Containers/WebPush/tests/reducer.test.js +0 -863
  214. package/v2Containers/WebPush/tests/sagas.test.js +0 -566
  215. package/v2Containers/WebPush/tests/selectors.test.js +0 -960
@@ -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
-