@capillarytech/creatives-library 8.0.242-alpha.0 → 8.0.242-alpha.2

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