@windstream/react-shared-components 0.1.45 → 0.1.46

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 (196) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.esm.js +3 -3
  3. package/dist/contentful/index.esm.js.map +1 -1
  4. package/dist/contentful/index.js +3 -3
  5. package/dist/contentful/index.js.map +1 -1
  6. package/dist/core.d.ts +1 -1
  7. package/dist/index.d.ts +3 -3
  8. package/dist/index.esm.js +5 -13
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js +5 -13
  11. package/dist/index.js.map +1 -1
  12. package/dist/next/index.esm.js +2 -2
  13. package/dist/next/index.esm.js.map +1 -1
  14. package/dist/next/index.js +2 -2
  15. package/dist/next/index.js.map +1 -1
  16. package/dist/styles.css +1 -1
  17. package/dist/utils/index.esm.js +1 -1
  18. package/dist/utils/index.esm.js.map +1 -1
  19. package/dist/utils/index.js +1 -1
  20. package/dist/utils/index.js.map +1 -1
  21. package/package.json +185 -185
  22. package/src/components/accordion/Accordion.stories.tsx +230 -230
  23. package/src/components/accordion/index.tsx +70 -70
  24. package/src/components/accordion/types.ts +12 -12
  25. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  26. package/src/components/alert-card/index.tsx +41 -41
  27. package/src/components/alert-card/types.ts +13 -13
  28. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  29. package/src/components/brand-button/helpers.ts +35 -35
  30. package/src/components/brand-button/index.tsx +120 -120
  31. package/src/components/brand-button/types.ts +38 -38
  32. package/src/components/button/Button.stories.tsx +108 -108
  33. package/src/components/button/index.tsx +27 -27
  34. package/src/components/button/types.ts +14 -14
  35. package/src/components/call-button/CallButton.stories.tsx +324 -324
  36. package/src/components/call-button/index.tsx +86 -86
  37. package/src/components/call-button/types.ts +11 -11
  38. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  39. package/src/components/checkbox/index.tsx +197 -197
  40. package/src/components/checkbox/types.ts +27 -27
  41. package/src/components/checklist/Checklist.stories.tsx +150 -150
  42. package/src/components/checklist/index.tsx +61 -61
  43. package/src/components/checklist/types.ts +17 -17
  44. package/src/components/collapse/Collapse.stories.tsx +255 -255
  45. package/src/components/collapse/index.tsx +46 -46
  46. package/src/components/collapse/types.ts +6 -6
  47. package/src/components/divider/Divider.stories.tsx +205 -205
  48. package/src/components/divider/index.tsx +22 -22
  49. package/src/components/divider/type.ts +3 -3
  50. package/src/components/image/Image.stories.tsx +113 -113
  51. package/src/components/image/index.tsx +25 -25
  52. package/src/components/image/types.ts +40 -40
  53. package/src/components/input/Input.stories.tsx +325 -325
  54. package/src/components/input/index.tsx +177 -177
  55. package/src/components/input/types.ts +37 -37
  56. package/src/components/link/Link.stories.tsx +163 -163
  57. package/src/components/link/index.tsx +109 -109
  58. package/src/components/link/types.ts +25 -25
  59. package/src/components/list/List.stories.tsx +272 -272
  60. package/src/components/list/index.tsx +88 -88
  61. package/src/components/list/list-item/index.tsx +38 -38
  62. package/src/components/list/list-item/types.ts +13 -13
  63. package/src/components/list/types.ts +29 -29
  64. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  65. package/src/components/material-icon/constants.ts +98 -98
  66. package/src/components/material-icon/index.tsx +47 -47
  67. package/src/components/material-icon/types.ts +31 -31
  68. package/src/components/modal/Modal.stories.tsx +171 -171
  69. package/src/components/modal/index.tsx +164 -164
  70. package/src/components/modal/types.ts +24 -24
  71. package/src/components/next-image/index.tsx +54 -54
  72. package/src/components/next-image/types.ts +1 -1
  73. package/src/components/pagination/index.tsx +100 -100
  74. package/src/components/pagination/types.ts +6 -6
  75. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  76. package/src/components/radio-button/index.tsx +75 -75
  77. package/src/components/radio-button/types.ts +21 -21
  78. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  79. package/src/components/see-more/index.tsx +44 -44
  80. package/src/components/see-more/types.ts +4 -4
  81. package/src/components/select/Select.stories.tsx +411 -411
  82. package/src/components/select/index.tsx +155 -155
  83. package/src/components/select/types.ts +36 -36
  84. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  85. package/src/components/select-plan-button/index.tsx +63 -63
  86. package/src/components/select-plan-button/types.ts +17 -17
  87. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  88. package/src/components/skeleton/index.tsx +61 -61
  89. package/src/components/skeleton/types.ts +4 -4
  90. package/src/components/spinner/Spinner.stories.tsx +335 -335
  91. package/src/components/spinner/index.tsx +44 -44
  92. package/src/components/spinner/types.ts +5 -5
  93. package/src/components/text/Text.stories.tsx +321 -321
  94. package/src/components/text/index.tsx +25 -25
  95. package/src/components/text/types.ts +45 -45
  96. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  97. package/src/components/tooltip/index.tsx +74 -74
  98. package/src/components/tooltip/types.ts +7 -7
  99. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  100. package/src/components/view-cart-button/index.tsx +42 -42
  101. package/src/components/view-cart-button/types.ts +5 -5
  102. package/src/contentful/blocks/accordion/Accordion.stories.tsx +34 -34
  103. package/src/contentful/blocks/accordion/index.tsx +112 -112
  104. package/src/contentful/blocks/accordion/types.ts +34 -34
  105. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  106. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  107. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +70 -70
  108. package/src/contentful/blocks/anchored-bottom-banner/types.ts +10 -10
  109. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  110. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  111. package/src/contentful/blocks/breadcrumbs/index.tsx +51 -51
  112. package/src/contentful/blocks/breadcrumbs/types.ts +5 -5
  113. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  114. package/src/contentful/blocks/button/index.tsx +130 -130
  115. package/src/contentful/blocks/button/types.ts +39 -39
  116. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  117. package/src/contentful/blocks/callout/index.tsx +88 -88
  118. package/src/contentful/blocks/callout/types.ts +15 -15
  119. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  120. package/src/contentful/blocks/cards/blog-card/index.tsx +110 -110
  121. package/src/contentful/blocks/cards/blog-card/types.ts +18 -18
  122. package/src/contentful/blocks/cards/index.tsx +13 -13
  123. package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
  124. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  125. package/src/contentful/blocks/cards/simple-card/index.tsx +89 -89
  126. package/src/contentful/blocks/cards/simple-card/types.ts +28 -28
  127. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  128. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  129. package/src/contentful/blocks/cards/types.ts +1 -1
  130. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  131. package/src/contentful/blocks/carousel/helper.tsx +440 -440
  132. package/src/contentful/blocks/carousel/index.tsx +85 -85
  133. package/src/contentful/blocks/carousel/types.ts +144 -144
  134. package/src/contentful/blocks/comparison-table/index.tsx +27 -27
  135. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  136. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  137. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  138. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  139. package/src/contentful/blocks/cta-callout/index.tsx +71 -71
  140. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  141. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  142. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  143. package/src/contentful/blocks/email-input-block/index.tsx +117 -117
  144. package/src/contentful/blocks/email-input-block/types.ts +16 -16
  145. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  146. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  147. package/src/contentful/blocks/find-kinetic/types.ts +19 -19
  148. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  149. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  150. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  151. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  152. package/src/contentful/blocks/footer/index.tsx +91 -91
  153. package/src/contentful/blocks/footer/types.ts +13 -13
  154. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  155. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  156. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  157. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  158. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  159. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  160. package/src/contentful/blocks/modal/constants.ts +53 -53
  161. package/src/contentful/blocks/modal/index.tsx +107 -107
  162. package/src/contentful/blocks/modal/types.ts +12 -12
  163. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +113 -113
  164. package/src/contentful/blocks/navigation/index.tsx +394 -394
  165. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  166. package/src/contentful/blocks/navigation/types.ts +41 -41
  167. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  168. package/src/contentful/blocks/primary-hero/index.tsx +236 -236
  169. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  170. package/src/contentful/blocks/search-block/index.tsx +90 -90
  171. package/src/contentful/blocks/search-block/types.ts +15 -15
  172. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  173. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  174. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  175. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  176. package/src/contentful/blocks/text/index.tsx +12 -12
  177. package/src/contentful/blocks/text/types.ts +1 -1
  178. package/src/contentful/index.ts +99 -99
  179. package/src/hooks/contentful/use-contentful-rich-text.tsx +310 -310
  180. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  181. package/src/hooks/use-body-scroll-lock.ts +34 -34
  182. package/src/hooks/use-carousel-swipe.ts +264 -264
  183. package/src/hooks/use-outside-click.ts +17 -17
  184. package/src/index.ts +101 -101
  185. package/src/next/index.ts +5 -5
  186. package/src/setupTests.ts +46 -46
  187. package/src/stories/DocsTemplate.tsx +24 -24
  188. package/src/styles/globals.css +343 -343
  189. package/src/types/global.d.ts +9 -9
  190. package/src/types/micro-components.ts +99 -99
  191. package/src/types/utm.ts +49 -49
  192. package/src/utils/contentful/to-document.ts +24 -24
  193. package/src/utils/cookie.ts +84 -84
  194. package/src/utils/cx.ts +49 -49
  195. package/src/utils/index.ts +38 -38
  196. package/src/utils/utm.ts +221 -221
@@ -1,85 +1,85 @@
1
- import React from "react";
2
- import { TabSwitch } from "../carousel/helper";
3
- import { ProductCardCarousel, TestimonialCarousel } from "./helper";
4
- import {
5
- CarouselProps,
6
- CarouselWithProductCards,
7
- CarouselWithTestimonialCards,
8
- } from "./types";
9
-
10
- import { Text } from "@shared/components/text";
11
-
12
- export const Carousel: React.FC<CarouselProps> = ({
13
- fields,
14
- hasTestimonialCards,
15
- hasProductCards,
16
- disclaimerText,
17
- backgroundColor,
18
- activeTab,
19
- setActiveTab,
20
- tabs,
21
- onModalButtonClick,
22
- renderCheckPlans,
23
- testimonialAutoScroll = true,
24
- showSwitch = false,
25
- }) => {
26
- const baseClass = hasProductCards
27
- ? "px-3 py-9 md:py-20"
28
- : hasTestimonialCards
29
- ? "px-3 py-12 md:pt-20 md:pb-16"
30
- : "";
31
- return (
32
- <div className={`${backgroundColor} ${baseClass} mx-auto overflow-hidden`}>
33
- <div className="relative mx-auto flex max-w-[1280px] flex-col gap-8 overflow-visible md:gap-12">
34
- <div>
35
- <Text
36
- as="h2"
37
- className="heading2 text-text md:heading1 md:text-center"
38
- >
39
- {fields?.title}
40
- </Text>
41
- {fields?.subTitle && (
42
- <Text as="h3" className="body1 px-4 pt-4 md:text-center">
43
- {fields?.subTitle}
44
- </Text>
45
- )}
46
- </div>
47
- {showSwitch && hasProductCards && (
48
- <div className="flex flex-col gap-8">
49
- {showSwitch && hasProductCards && tabs.length > 1 && (
50
- <TabSwitch
51
- tabs={tabs}
52
- activeTab={activeTab}
53
- onChange={setActiveTab}
54
- />
55
- )}
56
- {hasProductCards && (
57
- <ProductCardCarousel
58
- onModalButtonClick={onModalButtonClick}
59
- renderCheckPlans={renderCheckPlans}
60
- fields={fields as CarouselWithProductCards}
61
- />
62
- )}
63
- </div>
64
- )}
65
- {hasTestimonialCards && (
66
- <TestimonialCarousel
67
- fields={fields as CarouselWithTestimonialCards}
68
- autoScroll={testimonialAutoScroll}
69
- autoScrollInterval={8000}
70
- />
71
- )}
72
- </div>
73
- {disclaimerText && (
74
- <Text
75
- as="div"
76
- className="footnote mt-8 px-4 text-center text-text-secondary"
77
- >
78
- {disclaimerText}
79
- </Text>
80
- )}
81
- </div>
82
- );
83
- };
84
-
85
- export default Carousel;
1
+ import React from "react";
2
+ import { TabSwitch } from "../carousel/helper";
3
+ import { ProductCardCarousel, TestimonialCarousel } from "./helper";
4
+ import {
5
+ CarouselProps,
6
+ CarouselWithProductCards,
7
+ CarouselWithTestimonialCards,
8
+ } from "./types";
9
+
10
+ import { Text } from "@shared/components/text";
11
+
12
+ export const Carousel: React.FC<CarouselProps> = ({
13
+ fields,
14
+ hasTestimonialCards,
15
+ hasProductCards,
16
+ disclaimerText,
17
+ backgroundColor,
18
+ activeTab,
19
+ setActiveTab,
20
+ tabs,
21
+ onModalButtonClick,
22
+ renderCheckPlans,
23
+ testimonialAutoScroll = true,
24
+ showSwitch = false,
25
+ }) => {
26
+ const baseClass = hasProductCards
27
+ ? "px-3 py-9 md:py-20"
28
+ : hasTestimonialCards
29
+ ? "px-3 py-12 md:pt-20 md:pb-16"
30
+ : "";
31
+ return (
32
+ <div className={`${backgroundColor} ${baseClass} mx-auto overflow-hidden`}>
33
+ <div className="relative mx-auto flex max-w-[1280px] flex-col gap-8 overflow-visible md:gap-12">
34
+ <div>
35
+ <Text
36
+ as="h2"
37
+ className="heading2 text-text md:heading1 md:text-center"
38
+ >
39
+ {fields?.title}
40
+ </Text>
41
+ {fields?.subTitle && (
42
+ <Text as="h3" className="body1 px-4 pt-4 md:text-center">
43
+ {fields?.subTitle}
44
+ </Text>
45
+ )}
46
+ </div>
47
+ {showSwitch && hasProductCards && (
48
+ <div className="flex flex-col gap-8">
49
+ {showSwitch && hasProductCards && tabs.length > 1 && (
50
+ <TabSwitch
51
+ tabs={tabs}
52
+ activeTab={activeTab}
53
+ onChange={setActiveTab}
54
+ />
55
+ )}
56
+ {hasProductCards && (
57
+ <ProductCardCarousel
58
+ onModalButtonClick={onModalButtonClick}
59
+ renderCheckPlans={renderCheckPlans}
60
+ fields={fields as CarouselWithProductCards}
61
+ />
62
+ )}
63
+ </div>
64
+ )}
65
+ {hasTestimonialCards && (
66
+ <TestimonialCarousel
67
+ fields={fields as CarouselWithTestimonialCards}
68
+ autoScroll={testimonialAutoScroll}
69
+ autoScrollInterval={8000}
70
+ />
71
+ )}
72
+ </div>
73
+ {disclaimerText && (
74
+ <Text
75
+ as="div"
76
+ className="footnote mt-8 px-4 text-center text-text-secondary"
77
+ >
78
+ {disclaimerText}
79
+ </Text>
80
+ )}
81
+ </div>
82
+ );
83
+ };
84
+
85
+ export default Carousel;
@@ -1,144 +1,144 @@
1
- import React, { ReactNode } from "react";
2
-
3
- import { CheckPlansProps } from "@shared/types/micro-components";
4
-
5
- export interface carouselFieldsInterface {
6
- __typename: "ComponentCarousel";
7
- sys: {
8
- id: string;
9
- };
10
- entryName?: string;
11
- anchorId?: string;
12
- title?: string;
13
- subTitle?: string;
14
- rotationTiming?: number;
15
- showArrows?: boolean;
16
- autoRotate?: boolean;
17
- initialSlideIndex?: number;
18
- infiniteScroll?: boolean;
19
- mobileNavigationType?: boolean;
20
- disclaimerText?: {
21
- json: any;
22
- };
23
- backgroundColor?: "blue" | "green" | "orange" | "purple" | "white";
24
- items: {
25
- items: Array<CarouselItemsType>;
26
- };
27
- }
28
-
29
- export type CarouselItemsType =
30
- | TestimonialCardFields
31
- | ProductCardFields
32
- | CardFields;
33
-
34
- export interface TestimonialCardFields {
35
- __typename: "ComponentTestimonialCard";
36
- sys: {
37
- id: string;
38
- };
39
- title?: string;
40
- author?: string;
41
- role?: string;
42
- rating?: number;
43
- quote?: ReactNode;
44
- authorImage?: {
45
- url: string;
46
- title?: string;
47
- width?: number;
48
- height?: number;
49
- } | null;
50
- avatarurl?: string;
51
- }
52
-
53
- export interface ProductCardFields {
54
- __typename: "ComponentProductCard";
55
- sys: {
56
- id: string;
57
- };
58
- speed?: string;
59
- price?: string;
60
- priceSuffix?: string;
61
- techType?: string;
62
- highlighted?: boolean;
63
- productCardDescription?: string;
64
- benefitsTitle?: string;
65
- benefitsExpanded?: boolean;
66
- innerBadge?: string;
67
- // GraphQL patterns for nested references
68
- benefits?: {
69
- items: Array<any>;
70
- };
71
- giftRewards?: {
72
- list?: {
73
- items: Array<any>;
74
- };
75
- };
76
- cta?: {
77
- buttonLabel?: string;
78
- [key: string]: any;
79
- };
80
- innerBadgeIcon?: {
81
- url: string;
82
- [key: string]: any;
83
- };
84
- }
85
-
86
- export interface CardFields {
87
- __typename: "ComponentCard";
88
- sys: {
89
- id: string;
90
- };
91
- title?: string;
92
- subtitle?: string;
93
- eyebrow?: string;
94
- body?: { json: any };
95
- image?: { url: string; [key: string]: any };
96
- cta?: { buttonLabel?: string; [key: string]: any };
97
- ctaBottom?: { buttonLabel?: string; [key: string]: any };
98
- }
99
-
100
- export interface CarouselWithTestimonialCards
101
- extends Omit<carouselFieldsInterface, "items"> {
102
- items: {
103
- items: TestimonialCardFields[];
104
- };
105
- }
106
-
107
- export interface CarouselWithProductCards
108
- extends Omit<carouselFieldsInterface, "items"> {
109
- items: {
110
- items: ProductCardFields[];
111
- };
112
- }
113
-
114
- export const backgroundColorMap = {
115
- blue: "bg-bg-fill-inverse",
116
- green: "bg-border-success",
117
- orange: "bg-orange-500",
118
- purple: "bg-purple-500",
119
- white: "bg-white",
120
- };
121
-
122
- export type CarouselProps = {
123
- fields: carouselFieldsInterface;
124
- hasTestimonialCards: boolean;
125
- hasProductCards: boolean;
126
- disclaimerText: ReactNode;
127
- backgroundColor: string;
128
- activeTab: string;
129
- setActiveTab: (tab: string) => void;
130
- tabs: string[];
131
- showSwitch?: boolean;
132
- testimonialAutoScroll?: boolean;
133
- onModalButtonClick?: (id?: string) => void;
134
- renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
135
- };
136
-
137
- export interface TabSwitchProps {
138
- tabs: string[];
139
- activeTab: string;
140
- onChange: (tab: string) => void;
141
- className?: string;
142
- }
143
-
144
- export const DEFAULT_TABS = ["Business Ready", "Internet Only"];
1
+ import React, { ReactNode } from "react";
2
+
3
+ import { CheckPlansProps } from "@shared/types/micro-components";
4
+
5
+ export interface carouselFieldsInterface {
6
+ __typename: "ComponentCarousel";
7
+ sys: {
8
+ id: string;
9
+ };
10
+ entryName?: string;
11
+ anchorId?: string;
12
+ title?: string;
13
+ subTitle?: string;
14
+ rotationTiming?: number;
15
+ showArrows?: boolean;
16
+ autoRotate?: boolean;
17
+ initialSlideIndex?: number;
18
+ infiniteScroll?: boolean;
19
+ mobileNavigationType?: boolean;
20
+ disclaimerText?: {
21
+ json: any;
22
+ };
23
+ backgroundColor?: "blue" | "green" | "orange" | "purple" | "white";
24
+ items: {
25
+ items: Array<CarouselItemsType>;
26
+ };
27
+ }
28
+
29
+ export type CarouselItemsType =
30
+ | TestimonialCardFields
31
+ | ProductCardFields
32
+ | CardFields;
33
+
34
+ export interface TestimonialCardFields {
35
+ __typename: "ComponentTestimonialCard";
36
+ sys: {
37
+ id: string;
38
+ };
39
+ title?: string;
40
+ author?: string;
41
+ role?: string;
42
+ rating?: number;
43
+ quote?: ReactNode;
44
+ authorImage?: {
45
+ url: string;
46
+ title?: string;
47
+ width?: number;
48
+ height?: number;
49
+ } | null;
50
+ avatarurl?: string;
51
+ }
52
+
53
+ export interface ProductCardFields {
54
+ __typename: "ComponentProductCard";
55
+ sys: {
56
+ id: string;
57
+ };
58
+ speed?: string;
59
+ price?: string;
60
+ priceSuffix?: string;
61
+ techType?: string;
62
+ highlighted?: boolean;
63
+ productCardDescription?: string;
64
+ benefitsTitle?: string;
65
+ benefitsExpanded?: boolean;
66
+ innerBadge?: string;
67
+ // GraphQL patterns for nested references
68
+ benefits?: {
69
+ items: Array<any>;
70
+ };
71
+ giftRewards?: {
72
+ list?: {
73
+ items: Array<any>;
74
+ };
75
+ };
76
+ cta?: {
77
+ buttonLabel?: string;
78
+ [key: string]: any;
79
+ };
80
+ innerBadgeIcon?: {
81
+ url: string;
82
+ [key: string]: any;
83
+ };
84
+ }
85
+
86
+ export interface CardFields {
87
+ __typename: "ComponentCard";
88
+ sys: {
89
+ id: string;
90
+ };
91
+ title?: string;
92
+ subtitle?: string;
93
+ eyebrow?: string;
94
+ body?: { json: any };
95
+ image?: { url: string; [key: string]: any };
96
+ cta?: { buttonLabel?: string; [key: string]: any };
97
+ ctaBottom?: { buttonLabel?: string; [key: string]: any };
98
+ }
99
+
100
+ export interface CarouselWithTestimonialCards
101
+ extends Omit<carouselFieldsInterface, "items"> {
102
+ items: {
103
+ items: TestimonialCardFields[];
104
+ };
105
+ }
106
+
107
+ export interface CarouselWithProductCards
108
+ extends Omit<carouselFieldsInterface, "items"> {
109
+ items: {
110
+ items: ProductCardFields[];
111
+ };
112
+ }
113
+
114
+ export const backgroundColorMap = {
115
+ blue: "bg-bg-fill-inverse",
116
+ green: "bg-border-success",
117
+ orange: "bg-orange-500",
118
+ purple: "bg-purple-500",
119
+ white: "bg-white",
120
+ };
121
+
122
+ export type CarouselProps = {
123
+ fields: carouselFieldsInterface;
124
+ hasTestimonialCards: boolean;
125
+ hasProductCards: boolean;
126
+ disclaimerText: ReactNode;
127
+ backgroundColor: string;
128
+ activeTab: string;
129
+ setActiveTab: (tab: string) => void;
130
+ tabs: string[];
131
+ showSwitch?: boolean;
132
+ testimonialAutoScroll?: boolean;
133
+ onModalButtonClick?: (id?: string) => void;
134
+ renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
135
+ };
136
+
137
+ export interface TabSwitchProps {
138
+ tabs: string[];
139
+ activeTab: string;
140
+ onChange: (tab: string) => void;
141
+ className?: string;
142
+ }
143
+
144
+ export const DEFAULT_TABS = ["Business Ready", "Internet Only"];
@@ -1,27 +1,27 @@
1
- import React from "react";
2
- import { ComparisonTableProps } from "./types";
3
-
4
- import { Text } from "@shared/components/text";
5
-
6
- export const ComparisonTable: React.FC<ComparisonTableProps> = ({
7
- title,
8
- disclaimer,
9
- table,
10
- maxWidth = true,
11
- }) => {
12
- return (
13
- <div className="component-container">
14
- <div
15
- className={`mx-5 mb-5 mt-8 lg:mt-10 ${maxWidth ? "max-w-120 xl:mx-auto" : ""}`}
16
- >
17
- <Text as="h2" className="heading2 lg:heading1 lg:text-center">
18
- {title}
19
- </Text>
20
- <div className="comparison-table-container mt-20 xl:mt-10">{table}</div>
21
- <Text as="div" className="micro mt-8 text-center">
22
- {disclaimer}
23
- </Text>
24
- </div>
25
- </div>
26
- );
27
- };
1
+ import React from "react";
2
+ import { ComparisonTableProps } from "./types";
3
+
4
+ import { Text } from "@shared/components/text";
5
+
6
+ export const ComparisonTable: React.FC<ComparisonTableProps> = ({
7
+ title,
8
+ disclaimer,
9
+ table,
10
+ maxWidth = true,
11
+ }) => {
12
+ return (
13
+ <div className="component-container">
14
+ <div
15
+ className={`mx-5 mb-5 mt-8 lg:mt-10 ${maxWidth ? "max-w-120 xl:mx-auto" : ""}`}
16
+ >
17
+ <Text as="h2" className="heading2 lg:heading1 lg:text-center">
18
+ {title}
19
+ </Text>
20
+ <div className="comparison-table-container mt-20 xl:mt-10">{table}</div>
21
+ <Text as="div" className="micro mt-8 text-center">
22
+ {disclaimer}
23
+ </Text>
24
+ </div>
25
+ </div>
26
+ );
27
+ };
@@ -1,6 +1,6 @@
1
- export type ComparisonTableProps = {
2
- title?: string;
3
- disclaimer?: React.ReactNode;
4
- table: React.ReactNode;
5
- maxWidth?: boolean;
6
- };
1
+ export type ComparisonTableProps = {
2
+ title?: string;
3
+ disclaimer?: React.ReactNode;
4
+ table: React.ReactNode;
5
+ maxWidth?: boolean;
6
+ };