@windstream/react-shared-components 0.1.78 → 0.1.79

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 (204) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.d.ts +3 -1
  3. package/dist/contentful/index.esm.js +3 -3
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +2 -2
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +1 -1
  8. package/dist/index.d.ts +1 -1
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js.map +1 -1
  11. package/dist/next/index.esm.js.map +1 -1
  12. package/dist/next/index.js.map +1 -1
  13. package/dist/styles.css +1 -1
  14. package/dist/utils/index.esm.js.map +1 -1
  15. package/dist/utils/index.js.map +1 -1
  16. package/package.json +185 -185
  17. package/src/components/accordion/Accordion.stories.tsx +230 -230
  18. package/src/components/accordion/index.tsx +70 -70
  19. package/src/components/accordion/types.ts +12 -12
  20. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  21. package/src/components/alert-card/index.tsx +41 -41
  22. package/src/components/alert-card/types.ts +13 -13
  23. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  24. package/src/components/brand-button/helpers.ts +35 -35
  25. package/src/components/brand-button/index.tsx +120 -120
  26. package/src/components/brand-button/types.ts +38 -38
  27. package/src/components/button/Button.stories.tsx +108 -108
  28. package/src/components/button/index.tsx +27 -27
  29. package/src/components/button/types.ts +14 -14
  30. package/src/components/call-button/CallButton.stories.tsx +324 -324
  31. package/src/components/call-button/index.tsx +106 -106
  32. package/src/components/call-button/types.ts +16 -16
  33. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  34. package/src/components/checkbox/index.tsx +197 -197
  35. package/src/components/checkbox/types.ts +27 -27
  36. package/src/components/checklist/Checklist.stories.tsx +150 -150
  37. package/src/components/checklist/index.tsx +61 -61
  38. package/src/components/checklist/types.ts +17 -17
  39. package/src/components/collapse/Collapse.stories.tsx +255 -255
  40. package/src/components/collapse/index.tsx +46 -46
  41. package/src/components/collapse/types.ts +6 -6
  42. package/src/components/divider/Divider.stories.tsx +205 -205
  43. package/src/components/divider/index.tsx +22 -22
  44. package/src/components/divider/type.ts +3 -3
  45. package/src/components/image/Image.stories.tsx +113 -113
  46. package/src/components/image/index.tsx +25 -25
  47. package/src/components/image/types.ts +40 -40
  48. package/src/components/input/Input.stories.tsx +325 -325
  49. package/src/components/input/index.tsx +177 -177
  50. package/src/components/input/types.ts +37 -37
  51. package/src/components/link/Link.stories.tsx +163 -163
  52. package/src/components/link/index.tsx +116 -116
  53. package/src/components/link/types.ts +25 -25
  54. package/src/components/list/List.stories.tsx +272 -272
  55. package/src/components/list/index.tsx +88 -88
  56. package/src/components/list/list-item/index.tsx +38 -38
  57. package/src/components/list/list-item/types.ts +13 -13
  58. package/src/components/list/types.ts +29 -29
  59. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  60. package/src/components/material-icon/constants.ts +99 -99
  61. package/src/components/material-icon/index.tsx +47 -47
  62. package/src/components/material-icon/types.ts +31 -31
  63. package/src/components/modal/Modal.stories.tsx +171 -171
  64. package/src/components/modal/index.tsx +164 -164
  65. package/src/components/modal/types.ts +24 -24
  66. package/src/components/next-image/index.tsx +74 -74
  67. package/src/components/next-image/types.ts +1 -1
  68. package/src/components/pagination/index.tsx +91 -91
  69. package/src/components/pagination/types.ts +6 -6
  70. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  71. package/src/components/radio-button/index.tsx +75 -75
  72. package/src/components/radio-button/types.ts +21 -21
  73. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  74. package/src/components/see-more/index.tsx +44 -44
  75. package/src/components/see-more/types.ts +4 -4
  76. package/src/components/select/Select.stories.tsx +411 -411
  77. package/src/components/select/index.tsx +155 -155
  78. package/src/components/select/types.ts +36 -36
  79. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  80. package/src/components/select-plan-button/index.tsx +63 -63
  81. package/src/components/select-plan-button/types.ts +17 -17
  82. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  83. package/src/components/skeleton/index.tsx +61 -61
  84. package/src/components/skeleton/types.ts +4 -4
  85. package/src/components/spinner/Spinner.stories.tsx +335 -335
  86. package/src/components/spinner/index.tsx +44 -44
  87. package/src/components/spinner/types.ts +5 -5
  88. package/src/components/text/Text.stories.tsx +321 -321
  89. package/src/components/text/index.tsx +25 -25
  90. package/src/components/text/types.ts +45 -45
  91. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  92. package/src/components/tooltip/index.tsx +74 -74
  93. package/src/components/tooltip/types.ts +7 -7
  94. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  95. package/src/components/view-cart-button/index.tsx +42 -42
  96. package/src/components/view-cart-button/types.ts +5 -5
  97. package/src/contentful/blocks/accordion/Accordion.stories.mocks.tsx +128 -128
  98. package/src/contentful/blocks/accordion/Accordion.stories.tsx +98 -98
  99. package/src/contentful/blocks/accordion/index.tsx +112 -112
  100. package/src/contentful/blocks/accordion/types.ts +34 -34
  101. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  102. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  103. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +181 -181
  104. package/src/contentful/blocks/anchored-bottom-banner/types.ts +13 -13
  105. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.mocks.tsx +144 -0
  106. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +156 -0
  107. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  108. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  109. package/src/contentful/blocks/blogs-grid-base/index.tsx +119 -119
  110. package/src/contentful/blocks/blogs-grid-base/types.ts +36 -36
  111. package/src/contentful/blocks/breadcrumbs/BreadcrumbNavigation.stories.tsx +147 -0
  112. package/src/contentful/blocks/breadcrumbs/index.tsx +95 -81
  113. package/src/contentful/blocks/breadcrumbs/types.ts +8 -6
  114. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  115. package/src/contentful/blocks/button/index.tsx +131 -131
  116. package/src/contentful/blocks/button/types.ts +39 -39
  117. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  118. package/src/contentful/blocks/callout/index.tsx +265 -265
  119. package/src/contentful/blocks/callout/types.ts +72 -72
  120. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  121. package/src/contentful/blocks/cards/blog-card/index.tsx +129 -129
  122. package/src/contentful/blocks/cards/blog-card/types.ts +34 -34
  123. package/src/contentful/blocks/cards/floating-image-card/index.tsx +119 -119
  124. package/src/contentful/blocks/cards/floating-image-card/types.ts +30 -30
  125. package/src/contentful/blocks/cards/full-image-card/index.tsx +130 -130
  126. package/src/contentful/blocks/cards/full-image-card/types.ts +29 -29
  127. package/src/contentful/blocks/cards/index.tsx +13 -13
  128. package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
  129. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  130. package/src/contentful/blocks/cards/simple-card/index.tsx +325 -325
  131. package/src/contentful/blocks/cards/simple-card/types.ts +71 -71
  132. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  133. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  134. package/src/contentful/blocks/cards/types.ts +1 -1
  135. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  136. package/src/contentful/blocks/carousel/helper.tsx +440 -440
  137. package/src/contentful/blocks/carousel/index.tsx +85 -85
  138. package/src/contentful/blocks/carousel/types.ts +144 -144
  139. package/src/contentful/blocks/cart-retention-banner/index.tsx +105 -105
  140. package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
  141. package/src/contentful/blocks/comparison-table/index.tsx +29 -29
  142. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  143. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  144. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  145. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  146. package/src/contentful/blocks/cta-callout/index.tsx +71 -71
  147. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  148. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  149. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  150. package/src/contentful/blocks/email-input-block/index.tsx +116 -116
  151. package/src/contentful/blocks/email-input-block/types.ts +16 -16
  152. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  153. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  154. package/src/contentful/blocks/find-kinetic/types.ts +19 -19
  155. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  156. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  157. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  158. package/src/contentful/blocks/footer/Footer.stories.tsx +317 -317
  159. package/src/contentful/blocks/footer/index.tsx +91 -91
  160. package/src/contentful/blocks/footer/types.ts +13 -13
  161. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  162. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  163. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  164. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  165. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  166. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  167. package/src/contentful/blocks/modal/constants.ts +53 -53
  168. package/src/contentful/blocks/modal/index.tsx +107 -107
  169. package/src/contentful/blocks/modal/types.ts +12 -12
  170. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +139 -139
  171. package/src/contentful/blocks/navigation/index.tsx +568 -568
  172. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  173. package/src/contentful/blocks/navigation/types.ts +71 -71
  174. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  175. package/src/contentful/blocks/primary-hero/index.tsx +236 -236
  176. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  177. package/src/contentful/blocks/search-block/index.tsx +90 -90
  178. package/src/contentful/blocks/search-block/types.ts +15 -15
  179. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  180. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  181. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  182. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  183. package/src/contentful/blocks/text/index.tsx +12 -12
  184. package/src/contentful/blocks/text/types.ts +1 -1
  185. package/src/contentful/index.ts +105 -105
  186. package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
  187. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  188. package/src/hooks/use-body-scroll-lock.ts +34 -34
  189. package/src/hooks/use-carousel-swipe.ts +264 -264
  190. package/src/hooks/use-outside-click.ts +17 -17
  191. package/src/index.ts +101 -101
  192. package/src/next/index.ts +5 -5
  193. package/src/setupTests.ts +46 -46
  194. package/src/stories/DocsTemplate.tsx +24 -24
  195. package/src/styles/globals.css +343 -343
  196. package/src/types/global.d.ts +9 -9
  197. package/src/types/micro-components.ts +99 -99
  198. package/src/types/utm.ts +49 -49
  199. package/src/utils/contentful/to-document.ts +24 -24
  200. package/src/utils/cookie.ts +84 -84
  201. package/src/utils/cx.ts +49 -49
  202. package/src/utils/index.ts +41 -41
  203. package/src/utils/speed-card-bg.ts +24 -24
  204. package/src/utils/utm.ts +221 -221
@@ -1,236 +1,236 @@
1
- import React from "react";
2
- import { PrimaryHeroProps } from "./types";
3
-
4
- import { Checklist } from "@shared/components/checklist";
5
- import { NextImage } from "@shared/components/next-image";
6
- import { Text } from "@shared/components/text";
7
- import { Button } from "@shared/contentful/blocks/button";
8
- import { cx } from "@shared/utils";
9
-
10
- export const PrimaryHero: React.FC<PrimaryHeroProps> = props => {
11
- const {
12
- title,
13
- showAsHeading,
14
- subTitle,
15
- primaryCta1,
16
- carouselImages,
17
- bottomLink,
18
- price,
19
- priceCallout,
20
- priceSuffix,
21
- checklist,
22
- renderCheckPlans,
23
- badgeImage,
24
- pricingDescriptionDisclaimer,
25
- secondaryCta,
26
- secondaryCtaPrefix,
27
- onModalButtonClick,
28
- hideOnMobileCta1,
29
- } = props;
30
-
31
- const bottomLinkLabel = bottomLink?.buttonLabel ?? bottomLink?.label;
32
- console.log(primaryCta1);
33
- return (
34
- <div className="component-container p-5 lg:h-[724px] lg:p-0">
35
- <div
36
- className={cx(
37
- "primary-hero-container mx-auto flex flex-col sm:items-center sm:text-center lg:h-full lg:max-w-120 lg:flex-row lg:items-center lg:justify-between lg:gap-4 lg:px-4 lg:text-left"
38
- )}
39
- >
40
- {/* Left column: navy background, headline, body, address, button, link */}
41
- <div className={cx("relative flex flex-col text-white sm:w-[485px]")}>
42
- <div className="flex flex-col gap-5 lg:gap-6">
43
- {title && (
44
- <Text
45
- as={showAsHeading ? "h1" : "h2"}
46
- className="heading2 lg:heading1"
47
- >
48
- {title}
49
- </Text>
50
- )}
51
- {subTitle && (
52
- <Text as="p" className="subheading3 lg:subheading1">
53
- {subTitle}
54
- </Text>
55
- )}
56
-
57
- {/* price callout */}
58
- {price ? (
59
- <div className="flex sm:justify-center sm:text-left lg:justify-start">
60
- <div className="mr-2 mt-0.5">
61
- {priceCallout
62
- ? priceCallout.split("|").map((line, index) => (
63
- <Text key={index} as="p" className="body2">
64
- {line}
65
- </Text>
66
- ))
67
- : null}
68
- </div>
69
- <div className="flex">
70
- <Text as="p" className="subheading1 mt-0.5">
71
- $
72
- </Text>
73
- <Text as="p" className="subheading5">
74
- {price}
75
- </Text>
76
- {priceSuffix ? (
77
- <Text as="p" className="subheading1 mt-0.5">
78
- {priceSuffix}
79
- </Text>
80
- ) : null}
81
- </div>
82
- </div>
83
- ) : null}
84
-
85
- {/* checklist */}
86
- {checklist && (
87
- <Checklist
88
- listItemClassName="text-white text-left"
89
- items={checklist.map(item => item.title)}
90
- />
91
- )}
92
-
93
- {/* CTA section */}
94
- <div className="flex flex-col gap-3">
95
- {/* desktop CTA */}
96
- {primaryCta1 && (
97
- <div className={cx("md:block", hideOnMobileCta1 && "hidden")}>
98
- <Button
99
- {...primaryCta1}
100
- renderCheckPlans={renderCheckPlans}
101
- onModalButtonClick={onModalButtonClick}
102
- fullWidth={true}
103
- buttonClassName="md:w-auto"
104
- />
105
- </div>
106
- )}
107
- {secondaryCtaPrefix || secondaryCta ? (
108
- <div className="hidden md:flex">
109
- {secondaryCtaPrefix && (
110
- <Text as="span" className="body2 mr-1">
111
- {secondaryCtaPrefix}
112
- </Text>
113
- )}
114
- {secondaryCta && (
115
- <Button
116
- linkClassName="body2 text-text-inverse"
117
- onModalButtonClick={onModalButtonClick}
118
- {...secondaryCta}
119
- />
120
- )}
121
- </div>
122
- ) : null}
123
-
124
- {/* desktop bottom link */}
125
- {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
126
- <div className="hidden md:block">
127
- <Button
128
- {...bottomLink}
129
- linkClassName="text-footnote text-white"
130
- onModalButtonClick={onModalButtonClick}
131
- />
132
- </div>
133
- )}
134
-
135
- {pricingDescriptionDisclaimer ? (
136
- <Text as="p" className="body3 hidden md:block">
137
- {pricingDescriptionDisclaimer}
138
- </Text>
139
- ) : null}
140
- </div>
141
- </div>
142
- </div>
143
-
144
- {/* mobile hero image and bottom link */}
145
- <div className="lg:hidden">
146
- <div className={"relative my-8"}>
147
- {badgeImage ? (
148
- <NextImage
149
- src={badgeImage}
150
- alt={"Badge"}
151
- className="absolute left-5 top-5 aspect-square w-26 object-cover object-center"
152
- width={104}
153
- height={104}
154
- quality={90}
155
- loading="eager"
156
- />
157
- ) : null}
158
- {carouselImages && carouselImages[0] ? (
159
- <NextImage
160
- src={carouselImages[0]}
161
- alt={"Hero"}
162
- className="aspect-[1.71:1] sm:aspect-[1.41:1] w-full rounded-[40px] object-cover object-center sm:h-[420px]"
163
- width={1024}
164
- height={600}
165
- sizes="100vw"
166
- quality={90}
167
- loading="eager"
168
- />
169
- ) : null}
170
- </div>
171
-
172
- {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
173
- <div className="md:hidden">
174
- <Button
175
- {...bottomLink}
176
- onModalButtonClick={onModalButtonClick}
177
- linkClassName="body3 text-white"
178
- />
179
- </div>
180
- )}
181
-
182
- {pricingDescriptionDisclaimer ? (
183
- <Text as="p" className="body3 md:hidden">
184
- {pricingDescriptionDisclaimer}
185
- </Text>
186
- ) : null}
187
-
188
- {secondaryCtaPrefix || secondaryCta ? (
189
- <div className="flex md:hidden">
190
- {secondaryCtaPrefix && (
191
- <Text as="span" className="body2 mr-1">
192
- {secondaryCtaPrefix}
193
- </Text>
194
- )}
195
- {secondaryCta && (
196
- <Button
197
- {...secondaryCta}
198
- onModalButtonClick={onModalButtonClick}
199
- linkClassName="text-white"
200
- />
201
- )}
202
- </div>
203
- ) : null}
204
- </div>
205
-
206
- {/* Right column: bright blue background, diagonal top edge, hero image */}
207
- <div className={cx("relative hidden lg:block")}>
208
- {badgeImage ? (
209
- <NextImage
210
- src={badgeImage}
211
- alt={"Badge"}
212
- className="absolute -left-26 top-18 aspect-square w-52 object-cover object-center"
213
- width={208}
214
- height={208}
215
- quality={90}
216
- loading="eager"
217
- />
218
- ) : null}
219
- {carouselImages && carouselImages[0] ? (
220
- <NextImage
221
- src={carouselImages[0]}
222
- alt={"Hero"}
223
- className="aspect-square rounded-[40px] object-cover object-center"
224
- width={600}
225
- height={600}
226
- quality={90}
227
- loading="eager"
228
- />
229
- ) : null}
230
- </div>
231
- </div>
232
- </div>
233
- );
234
- };
235
-
236
- export default PrimaryHero;
1
+ import React from "react";
2
+ import { PrimaryHeroProps } from "./types";
3
+
4
+ import { Checklist } from "@shared/components/checklist";
5
+ import { NextImage } from "@shared/components/next-image";
6
+ import { Text } from "@shared/components/text";
7
+ import { Button } from "@shared/contentful/blocks/button";
8
+ import { cx } from "@shared/utils";
9
+
10
+ export const PrimaryHero: React.FC<PrimaryHeroProps> = props => {
11
+ const {
12
+ title,
13
+ showAsHeading,
14
+ subTitle,
15
+ primaryCta1,
16
+ carouselImages,
17
+ bottomLink,
18
+ price,
19
+ priceCallout,
20
+ priceSuffix,
21
+ checklist,
22
+ renderCheckPlans,
23
+ badgeImage,
24
+ pricingDescriptionDisclaimer,
25
+ secondaryCta,
26
+ secondaryCtaPrefix,
27
+ onModalButtonClick,
28
+ hideOnMobileCta1,
29
+ } = props;
30
+
31
+ const bottomLinkLabel = bottomLink?.buttonLabel ?? bottomLink?.label;
32
+ console.log(primaryCta1);
33
+ return (
34
+ <div className="component-container p-5 lg:h-[724px] lg:p-0">
35
+ <div
36
+ className={cx(
37
+ "primary-hero-container mx-auto flex flex-col sm:items-center sm:text-center lg:h-full lg:max-w-120 lg:flex-row lg:items-center lg:justify-between lg:gap-4 lg:px-4 lg:text-left"
38
+ )}
39
+ >
40
+ {/* Left column: navy background, headline, body, address, button, link */}
41
+ <div className={cx("relative flex flex-col text-white sm:w-[485px]")}>
42
+ <div className="flex flex-col gap-5 lg:gap-6">
43
+ {title && (
44
+ <Text
45
+ as={showAsHeading ? "h1" : "h2"}
46
+ className="heading2 lg:heading1"
47
+ >
48
+ {title}
49
+ </Text>
50
+ )}
51
+ {subTitle && (
52
+ <Text as="p" className="subheading3 lg:subheading1">
53
+ {subTitle}
54
+ </Text>
55
+ )}
56
+
57
+ {/* price callout */}
58
+ {price ? (
59
+ <div className="flex sm:justify-center sm:text-left lg:justify-start">
60
+ <div className="mr-2 mt-0.5">
61
+ {priceCallout
62
+ ? priceCallout.split("|").map((line, index) => (
63
+ <Text key={index} as="p" className="body2">
64
+ {line}
65
+ </Text>
66
+ ))
67
+ : null}
68
+ </div>
69
+ <div className="flex">
70
+ <Text as="p" className="subheading1 mt-0.5">
71
+ $
72
+ </Text>
73
+ <Text as="p" className="subheading5">
74
+ {price}
75
+ </Text>
76
+ {priceSuffix ? (
77
+ <Text as="p" className="subheading1 mt-0.5">
78
+ {priceSuffix}
79
+ </Text>
80
+ ) : null}
81
+ </div>
82
+ </div>
83
+ ) : null}
84
+
85
+ {/* checklist */}
86
+ {checklist && (
87
+ <Checklist
88
+ listItemClassName="text-white text-left"
89
+ items={checklist.map(item => item.title)}
90
+ />
91
+ )}
92
+
93
+ {/* CTA section */}
94
+ <div className="flex flex-col gap-3">
95
+ {/* desktop CTA */}
96
+ {primaryCta1 && (
97
+ <div className={cx("md:block", hideOnMobileCta1 && "hidden")}>
98
+ <Button
99
+ {...primaryCta1}
100
+ renderCheckPlans={renderCheckPlans}
101
+ onModalButtonClick={onModalButtonClick}
102
+ fullWidth={true}
103
+ buttonClassName="md:w-auto"
104
+ />
105
+ </div>
106
+ )}
107
+ {secondaryCtaPrefix || secondaryCta ? (
108
+ <div className="hidden md:flex">
109
+ {secondaryCtaPrefix && (
110
+ <Text as="span" className="body2 mr-1">
111
+ {secondaryCtaPrefix}
112
+ </Text>
113
+ )}
114
+ {secondaryCta && (
115
+ <Button
116
+ linkClassName="body2 text-text-inverse"
117
+ onModalButtonClick={onModalButtonClick}
118
+ {...secondaryCta}
119
+ />
120
+ )}
121
+ </div>
122
+ ) : null}
123
+
124
+ {/* desktop bottom link */}
125
+ {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
126
+ <div className="hidden md:block">
127
+ <Button
128
+ {...bottomLink}
129
+ linkClassName="text-footnote text-white"
130
+ onModalButtonClick={onModalButtonClick}
131
+ />
132
+ </div>
133
+ )}
134
+
135
+ {pricingDescriptionDisclaimer ? (
136
+ <Text as="p" className="body3 hidden md:block">
137
+ {pricingDescriptionDisclaimer}
138
+ </Text>
139
+ ) : null}
140
+ </div>
141
+ </div>
142
+ </div>
143
+
144
+ {/* mobile hero image and bottom link */}
145
+ <div className="lg:hidden">
146
+ <div className={"relative my-8"}>
147
+ {badgeImage ? (
148
+ <NextImage
149
+ src={badgeImage}
150
+ alt={"Badge"}
151
+ className="absolute left-5 top-5 aspect-square w-26 object-cover object-center"
152
+ width={104}
153
+ height={104}
154
+ quality={90}
155
+ loading="eager"
156
+ />
157
+ ) : null}
158
+ {carouselImages && carouselImages[0] ? (
159
+ <NextImage
160
+ src={carouselImages[0]}
161
+ alt={"Hero"}
162
+ className="aspect-[1.71:1] sm:aspect-[1.41:1] w-full rounded-[40px] object-cover object-center sm:h-[420px]"
163
+ width={1024}
164
+ height={600}
165
+ sizes="100vw"
166
+ quality={90}
167
+ loading="eager"
168
+ />
169
+ ) : null}
170
+ </div>
171
+
172
+ {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
173
+ <div className="md:hidden">
174
+ <Button
175
+ {...bottomLink}
176
+ onModalButtonClick={onModalButtonClick}
177
+ linkClassName="body3 text-white"
178
+ />
179
+ </div>
180
+ )}
181
+
182
+ {pricingDescriptionDisclaimer ? (
183
+ <Text as="p" className="body3 md:hidden">
184
+ {pricingDescriptionDisclaimer}
185
+ </Text>
186
+ ) : null}
187
+
188
+ {secondaryCtaPrefix || secondaryCta ? (
189
+ <div className="flex md:hidden">
190
+ {secondaryCtaPrefix && (
191
+ <Text as="span" className="body2 mr-1">
192
+ {secondaryCtaPrefix}
193
+ </Text>
194
+ )}
195
+ {secondaryCta && (
196
+ <Button
197
+ {...secondaryCta}
198
+ onModalButtonClick={onModalButtonClick}
199
+ linkClassName="text-white"
200
+ />
201
+ )}
202
+ </div>
203
+ ) : null}
204
+ </div>
205
+
206
+ {/* Right column: bright blue background, diagonal top edge, hero image */}
207
+ <div className={cx("relative hidden lg:block")}>
208
+ {badgeImage ? (
209
+ <NextImage
210
+ src={badgeImage}
211
+ alt={"Badge"}
212
+ className="absolute -left-26 top-18 aspect-square w-52 object-cover object-center"
213
+ width={208}
214
+ height={208}
215
+ quality={90}
216
+ loading="eager"
217
+ />
218
+ ) : null}
219
+ {carouselImages && carouselImages[0] ? (
220
+ <NextImage
221
+ src={carouselImages[0]}
222
+ alt={"Hero"}
223
+ className="aspect-square rounded-[40px] object-cover object-center"
224
+ width={600}
225
+ height={600}
226
+ quality={90}
227
+ loading="eager"
228
+ />
229
+ ) : null}
230
+ </div>
231
+ </div>
232
+ </div>
233
+ );
234
+ };
235
+
236
+ export default PrimaryHero;
@@ -1,37 +1,37 @@
1
- import React from "react";
2
-
3
- import { CheckPlansProps } from "@shared/types/micro-components";
4
-
5
- export type PrimaryHeroProps = {
6
- title: string;
7
- showAsHeading?: boolean;
8
- subTitle?: string;
9
- price?: string;
10
- priceSuffix?: string;
11
- priceCallout?: string;
12
- pricingDescription?: string;
13
- pricingDescriptionDisclaimer?: string;
14
- checklist?: {
15
- title: string;
16
- iconUrl?: string;
17
- anchorId?: string;
18
- }[];
19
- logoLockup?: string;
20
- checkAvailabilityEyebrow?: string;
21
- primaryCtaPrefix1?: string;
22
- primaryCtaPrefix2?: string;
23
- primaryCta1?: any;
24
- primaryCta2?: any;
25
- hideOnMobileCta1?: boolean;
26
- hideOnMobileCta2?: boolean;
27
- secondaryCtaPrefix?: string;
28
- secondaryCta?: any;
29
- bottomLink?: any;
30
- carouselImages?: string[];
31
- squareImage?: boolean;
32
- badgeImage?: string;
33
- textColor?: string;
34
- maxWidth?: boolean;
35
- renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
36
- onModalButtonClick?: (id?: string) => void;
37
- };
1
+ import React from "react";
2
+
3
+ import { CheckPlansProps } from "@shared/types/micro-components";
4
+
5
+ export type PrimaryHeroProps = {
6
+ title: string;
7
+ showAsHeading?: boolean;
8
+ subTitle?: string;
9
+ price?: string;
10
+ priceSuffix?: string;
11
+ priceCallout?: string;
12
+ pricingDescription?: string;
13
+ pricingDescriptionDisclaimer?: string;
14
+ checklist?: {
15
+ title: string;
16
+ iconUrl?: string;
17
+ anchorId?: string;
18
+ }[];
19
+ logoLockup?: string;
20
+ checkAvailabilityEyebrow?: string;
21
+ primaryCtaPrefix1?: string;
22
+ primaryCtaPrefix2?: string;
23
+ primaryCta1?: any;
24
+ primaryCta2?: any;
25
+ hideOnMobileCta1?: boolean;
26
+ hideOnMobileCta2?: boolean;
27
+ secondaryCtaPrefix?: string;
28
+ secondaryCta?: any;
29
+ bottomLink?: any;
30
+ carouselImages?: string[];
31
+ squareImage?: boolean;
32
+ badgeImage?: string;
33
+ textColor?: string;
34
+ maxWidth?: boolean;
35
+ renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
36
+ onModalButtonClick?: (id?: string) => void;
37
+ };