@windstream/react-shared-components 0.0.79 → 0.0.81

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 (136) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.esm.js +1 -1
  3. package/dist/contentful/index.js +1 -1
  4. package/dist/core.d.ts +1 -1
  5. package/dist/index.js.map +1 -1
  6. package/dist/styles.css +1 -1
  7. package/package.json +175 -175
  8. package/src/components/accordion/Accordion.stories.tsx +230 -230
  9. package/src/components/accordion/types.ts +10 -10
  10. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  11. package/src/components/alert-card/index.tsx +32 -32
  12. package/src/components/alert-card/types.ts +9 -9
  13. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  14. package/src/components/brand-button/helpers.ts +35 -35
  15. package/src/components/brand-button/index.tsx +115 -115
  16. package/src/components/brand-button/types.ts +37 -37
  17. package/src/components/button/Button.stories.tsx +108 -108
  18. package/src/components/button/index.tsx +27 -27
  19. package/src/components/button/types.ts +14 -14
  20. package/src/components/call-button/CallButton.stories.tsx +324 -324
  21. package/src/components/call-button/index.tsx +86 -86
  22. package/src/components/call-button/types.ts +11 -11
  23. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  24. package/src/components/checkbox/index.tsx +197 -197
  25. package/src/components/checkbox/types.ts +27 -27
  26. package/src/components/checklist/Checklist.stories.tsx +150 -150
  27. package/src/components/collapse/Collapse.stories.tsx +255 -255
  28. package/src/components/collapse/index.tsx +46 -46
  29. package/src/components/collapse/types.ts +6 -6
  30. package/src/components/divider/Divider.stories.tsx +205 -205
  31. package/src/components/divider/index.tsx +22 -22
  32. package/src/components/divider/type.ts +3 -3
  33. package/src/components/image/Image.stories.tsx +113 -113
  34. package/src/components/image/index.tsx +25 -25
  35. package/src/components/image/types.ts +40 -40
  36. package/src/components/input/Input.stories.tsx +325 -325
  37. package/src/components/input/index.tsx +177 -177
  38. package/src/components/input/types.ts +37 -37
  39. package/src/components/link/Link.stories.tsx +163 -163
  40. package/src/components/link/types.ts +25 -25
  41. package/src/components/list/List.stories.tsx +272 -272
  42. package/src/components/list/index.tsx +88 -88
  43. package/src/components/list/list-item/index.tsx +38 -38
  44. package/src/components/list/list-item/types.ts +13 -13
  45. package/src/components/list/types.ts +29 -29
  46. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  47. package/src/components/material-icon/constants.ts +96 -96
  48. package/src/components/material-icon/index.tsx +44 -44
  49. package/src/components/material-icon/types.ts +31 -31
  50. package/src/components/modal/Modal.stories.tsx +171 -171
  51. package/src/components/modal/index.tsx +164 -164
  52. package/src/components/modal/types.ts +24 -24
  53. package/src/components/next-image/index.tsx +32 -32
  54. package/src/components/next-image/types.ts +1 -1
  55. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  56. package/src/components/radio-button/index.tsx +75 -75
  57. package/src/components/radio-button/types.ts +21 -21
  58. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  59. package/src/components/see-more/index.tsx +44 -44
  60. package/src/components/see-more/types.ts +4 -4
  61. package/src/components/select/Select.stories.tsx +411 -411
  62. package/src/components/select/index.tsx +150 -150
  63. package/src/components/select/types.ts +35 -35
  64. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  65. package/src/components/select-plan-button/index.tsx +31 -31
  66. package/src/components/select-plan-button/types.ts +5 -5
  67. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  68. package/src/components/skeleton/index.tsx +61 -61
  69. package/src/components/skeleton/types.ts +4 -4
  70. package/src/components/spinner/Spinner.stories.tsx +335 -335
  71. package/src/components/spinner/index.tsx +44 -44
  72. package/src/components/spinner/types.ts +5 -5
  73. package/src/components/text/Text.stories.tsx +321 -321
  74. package/src/components/text/index.tsx +25 -25
  75. package/src/components/text/types.ts +45 -45
  76. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  77. package/src/components/tooltip/index.tsx +74 -74
  78. package/src/components/tooltip/types.ts +7 -7
  79. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  80. package/src/components/view-cart-button/index.tsx +44 -44
  81. package/src/components/view-cart-button/types.ts +5 -5
  82. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  83. package/src/contentful/blocks/button/index.tsx +85 -85
  84. package/src/contentful/blocks/button/types.ts +26 -26
  85. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  86. package/src/contentful/blocks/callout/index.tsx +66 -66
  87. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  88. package/src/contentful/blocks/cards/index.tsx +13 -13
  89. package/src/contentful/blocks/cards/product-card/index.tsx +199 -199
  90. package/src/contentful/blocks/cards/product-card/types.ts +18 -18
  91. package/src/contentful/blocks/cards/simple-card/index.tsx +77 -77
  92. package/src/contentful/blocks/cards/simple-card/types.ts +31 -31
  93. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  94. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  95. package/src/contentful/blocks/cards/types.ts +1 -1
  96. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  97. package/src/contentful/blocks/carousel/helper.tsx +314 -314
  98. package/src/contentful/blocks/carousel/index.tsx +50 -50
  99. package/src/contentful/blocks/carousel/types.ts +126 -126
  100. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  101. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  102. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  103. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  104. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  105. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  106. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  107. package/src/contentful/blocks/image-promo-bar/index.tsx +1 -1
  108. package/src/contentful/blocks/image-promo-bar/types.ts +27 -27
  109. package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
  110. package/src/contentful/blocks/modal/index.tsx +12 -12
  111. package/src/contentful/blocks/modal/types.ts +1 -1
  112. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  113. package/src/contentful/blocks/navigation/index.tsx +380 -380
  114. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  115. package/src/contentful/blocks/navigation/types.ts +41 -41
  116. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  117. package/src/contentful/blocks/primary-hero/index.tsx +212 -212
  118. package/src/contentful/blocks/primary-hero/types.ts +30 -30
  119. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  120. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  121. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  122. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  123. package/src/contentful/blocks/text/index.tsx +12 -12
  124. package/src/contentful/blocks/text/types.ts +1 -1
  125. package/src/contentful/index.ts +57 -57
  126. package/src/hooks/use-body-scroll-lock.ts +34 -34
  127. package/src/hooks/use-outside-click.ts +17 -17
  128. package/src/index.ts +96 -96
  129. package/src/next/index.ts +5 -5
  130. package/src/setupTests.ts +46 -46
  131. package/src/stories/DocsTemplate.tsx +24 -24
  132. package/src/styles/globals.css +307 -307
  133. package/src/types/global.d.ts +9 -9
  134. package/src/types/micro-components.ts +80 -80
  135. package/src/utils/index.ts +49 -49
  136. package/tailwind.config.cjs +60 -64
@@ -1,50 +1,50 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import { ProductCardCarousel, TestimonialCarousel } from "./helper";
5
- import {
6
- CarouselProps,
7
- CarouselWithProductCards,
8
- CarouselWithTestimonialCards,
9
- } from "./types";
10
-
11
- import { Text } from "@shared/components/text";
12
-
13
- export const Carousel: React.FC<CarouselProps> = ({
14
- fields,
15
- hasTestimonialCards,
16
- hasProductCards,
17
- disclaimerText,
18
- backgroundColor,
19
- }) => {
20
- return (
21
- <div className={`${backgroundColor} mx-auto overflow-hidden px-4 py-8`}>
22
- <div className="relative mx-auto flex max-w-[1280px] flex-col gap-12 overflow-visible">
23
- <Text
24
- as="h2"
25
- className="text-center text-4xl font-bold text-text md:text-5xl"
26
- >
27
- {fields?.title}
28
- </Text>
29
- {fields?.subTitle && (
30
- <Text as="h3" className="body1 mt-8 px-4 text-center">
31
- {fields?.subTitle}
32
- </Text>
33
- )}
34
- {hasTestimonialCards && (
35
- <TestimonialCarousel
36
- fields={fields as CarouselWithTestimonialCards}
37
- />
38
- )}
39
- {hasProductCards && (
40
- <ProductCardCarousel fields={fields as CarouselWithProductCards} />
41
- )}
42
- <Text as="div" className="body1 mt-8 px-4 text-center">
43
- {disclaimerText}
44
- </Text>
45
- </div>
46
- </div>
47
- );
48
- };
49
-
50
- export default Carousel;
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import { ProductCardCarousel, TestimonialCarousel } from "./helper";
5
+ import {
6
+ CarouselProps,
7
+ CarouselWithProductCards,
8
+ CarouselWithTestimonialCards,
9
+ } from "./types";
10
+
11
+ import { Text } from "@shared/components/text";
12
+
13
+ export const Carousel: React.FC<CarouselProps> = ({
14
+ fields,
15
+ hasTestimonialCards,
16
+ hasProductCards,
17
+ disclaimerText,
18
+ backgroundColor,
19
+ }) => {
20
+ return (
21
+ <div className={`${backgroundColor} mx-auto overflow-hidden px-4 py-8`}>
22
+ <div className="relative mx-auto flex max-w-[1280px] flex-col gap-12 overflow-visible">
23
+ <Text
24
+ as="h2"
25
+ className="text-center text-4xl font-bold text-text md:text-5xl"
26
+ >
27
+ {fields?.title}
28
+ </Text>
29
+ {fields?.subTitle && (
30
+ <Text as="h3" className="body1 mt-8 px-4 text-center">
31
+ {fields?.subTitle}
32
+ </Text>
33
+ )}
34
+ {hasTestimonialCards && (
35
+ <TestimonialCarousel
36
+ fields={fields as CarouselWithTestimonialCards}
37
+ />
38
+ )}
39
+ {hasProductCards && (
40
+ <ProductCardCarousel fields={fields as CarouselWithProductCards} />
41
+ )}
42
+ <Text as="div" className="body1 mt-8 px-4 text-center">
43
+ {disclaimerText}
44
+ </Text>
45
+ </div>
46
+ </div>
47
+ );
48
+ };
49
+
50
+ export default Carousel;
@@ -1,126 +1,126 @@
1
- import { ReactNode } from "react";
2
-
3
- export interface carouselFieldsInterface {
4
- __typename: "ComponentCarousel";
5
- sys: {
6
- id: string;
7
- };
8
- entryName?: string;
9
- anchorId?: string;
10
- title?: string;
11
- subTitle?: string;
12
- rotationTiming?: number;
13
- showArrows?: boolean;
14
- autoRotate?: boolean;
15
- initialSlideIndex?: number;
16
- infiniteScroll?: boolean;
17
- mobileNavigationType?: boolean;
18
- disclaimerText?: {
19
- json: any;
20
- };
21
- backgroundColor?: "blue" | "green" | "orange" | "purple" | "white";
22
- items: {
23
- items: Array<CarouselItemsType>;
24
- };
25
- }
26
-
27
- export type CarouselItemsType =
28
- | TestimonialCardFields
29
- | ProductCardFields
30
- | CardFields;
31
-
32
- export interface TestimonialCardFields {
33
- __typename: "ComponentTestimonialCard";
34
- sys: {
35
- id: string;
36
- };
37
- title?: string;
38
- author?: string;
39
- role?: string;
40
- rating?: number;
41
- quote?: ReactNode;
42
- authorImage?: {
43
- url: string;
44
- title?: string;
45
- width?: number;
46
- height?: number;
47
- } | null;
48
- avatarurl?: string;
49
- }
50
-
51
- export interface ProductCardFields {
52
- __typename: "ComponentProductCard";
53
- sys: {
54
- id: string;
55
- };
56
- speed?: string;
57
- price?: string;
58
- priceSuffix?: string;
59
- techType?: string;
60
- highlighted?: boolean;
61
- productCardDescription?: string;
62
- benefitsTitle?: string;
63
- benefitsExpanded?: boolean;
64
- innerBadge?: string;
65
- // GraphQL patterns for nested references
66
- benefits?: {
67
- items: Array<any>;
68
- };
69
- giftRewards?: {
70
- list?: {
71
- items: Array<any>;
72
- };
73
- };
74
- cta?: {
75
- buttonLabel?: string;
76
- [key: string]: any;
77
- };
78
- innerBadgeIcon?: {
79
- url: string;
80
- [key: string]: any;
81
- };
82
- }
83
-
84
- export interface CardFields {
85
- __typename: "ComponentCard";
86
- sys: {
87
- id: string;
88
- };
89
- title?: string;
90
- subtitle?: string;
91
- eyebrow?: string;
92
- body?: { json: any };
93
- image?: { url: string; [key: string]: any };
94
- cta?: { buttonLabel?: string; [key: string]: any };
95
- ctaBottom?: { buttonLabel?: string; [key: string]: any };
96
- }
97
-
98
- export interface CarouselWithTestimonialCards
99
- extends Omit<carouselFieldsInterface, "items"> {
100
- items: {
101
- items: TestimonialCardFields[];
102
- };
103
- }
104
-
105
- export interface CarouselWithProductCards
106
- extends Omit<carouselFieldsInterface, "items"> {
107
- items: {
108
- items: ProductCardFields[];
109
- };
110
- }
111
-
112
- export const backgroundColorMap = {
113
- blue: "bg-bg-fill-inverse",
114
- green: "bg-border-success",
115
- orange: "bg-orange-500",
116
- purple: "bg-purple-500",
117
- white: "bg-white",
118
- };
119
-
120
- export type CarouselProps = {
121
- fields: carouselFieldsInterface;
122
- hasTestimonialCards: boolean;
123
- hasProductCards: boolean;
124
- disclaimerText: ReactNode;
125
- backgroundColor: string;
126
- };
1
+ import { ReactNode } from "react";
2
+
3
+ export interface carouselFieldsInterface {
4
+ __typename: "ComponentCarousel";
5
+ sys: {
6
+ id: string;
7
+ };
8
+ entryName?: string;
9
+ anchorId?: string;
10
+ title?: string;
11
+ subTitle?: string;
12
+ rotationTiming?: number;
13
+ showArrows?: boolean;
14
+ autoRotate?: boolean;
15
+ initialSlideIndex?: number;
16
+ infiniteScroll?: boolean;
17
+ mobileNavigationType?: boolean;
18
+ disclaimerText?: {
19
+ json: any;
20
+ };
21
+ backgroundColor?: "blue" | "green" | "orange" | "purple" | "white";
22
+ items: {
23
+ items: Array<CarouselItemsType>;
24
+ };
25
+ }
26
+
27
+ export type CarouselItemsType =
28
+ | TestimonialCardFields
29
+ | ProductCardFields
30
+ | CardFields;
31
+
32
+ export interface TestimonialCardFields {
33
+ __typename: "ComponentTestimonialCard";
34
+ sys: {
35
+ id: string;
36
+ };
37
+ title?: string;
38
+ author?: string;
39
+ role?: string;
40
+ rating?: number;
41
+ quote?: ReactNode;
42
+ authorImage?: {
43
+ url: string;
44
+ title?: string;
45
+ width?: number;
46
+ height?: number;
47
+ } | null;
48
+ avatarurl?: string;
49
+ }
50
+
51
+ export interface ProductCardFields {
52
+ __typename: "ComponentProductCard";
53
+ sys: {
54
+ id: string;
55
+ };
56
+ speed?: string;
57
+ price?: string;
58
+ priceSuffix?: string;
59
+ techType?: string;
60
+ highlighted?: boolean;
61
+ productCardDescription?: string;
62
+ benefitsTitle?: string;
63
+ benefitsExpanded?: boolean;
64
+ innerBadge?: string;
65
+ // GraphQL patterns for nested references
66
+ benefits?: {
67
+ items: Array<any>;
68
+ };
69
+ giftRewards?: {
70
+ list?: {
71
+ items: Array<any>;
72
+ };
73
+ };
74
+ cta?: {
75
+ buttonLabel?: string;
76
+ [key: string]: any;
77
+ };
78
+ innerBadgeIcon?: {
79
+ url: string;
80
+ [key: string]: any;
81
+ };
82
+ }
83
+
84
+ export interface CardFields {
85
+ __typename: "ComponentCard";
86
+ sys: {
87
+ id: string;
88
+ };
89
+ title?: string;
90
+ subtitle?: string;
91
+ eyebrow?: string;
92
+ body?: { json: any };
93
+ image?: { url: string; [key: string]: any };
94
+ cta?: { buttonLabel?: string; [key: string]: any };
95
+ ctaBottom?: { buttonLabel?: string; [key: string]: any };
96
+ }
97
+
98
+ export interface CarouselWithTestimonialCards
99
+ extends Omit<carouselFieldsInterface, "items"> {
100
+ items: {
101
+ items: TestimonialCardFields[];
102
+ };
103
+ }
104
+
105
+ export interface CarouselWithProductCards
106
+ extends Omit<carouselFieldsInterface, "items"> {
107
+ items: {
108
+ items: ProductCardFields[];
109
+ };
110
+ }
111
+
112
+ export const backgroundColorMap = {
113
+ blue: "bg-bg-fill-inverse",
114
+ green: "bg-border-success",
115
+ orange: "bg-orange-500",
116
+ purple: "bg-purple-500",
117
+ white: "bg-white",
118
+ };
119
+
120
+ export type CarouselProps = {
121
+ fields: carouselFieldsInterface;
122
+ hasTestimonialCards: boolean;
123
+ hasProductCards: boolean;
124
+ disclaimerText: ReactNode;
125
+ backgroundColor: string;
126
+ };
@@ -1,46 +1,46 @@
1
- import { CtaCallout } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof CtaCallout> = {
7
- title: "Contentful Blocks/CtaCallout",
8
- component: CtaCallout,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component:
16
- "Contentful CTA callout block with title, description, and optional button.",
17
- },
18
- },
19
- },
20
- args: {
21
- title: "Call to Action",
22
- subTitle: "Subtitle",
23
- description: "Description text.",
24
- background: "white",
25
- button: {
26
- showButtonAs: "solid",
27
- buttonVariant: "primary_brand",
28
- buttonLabel: "Learn More",
29
- buttonPrefix: "",
30
- badge: "",
31
- badgeIcon: "",
32
- buttonIcon: "",
33
- buttonIconPosition: "left",
34
- href: "",
35
- target: "_self",
36
- anchorId: "",
37
- preserveQueryParameters: false,
38
- clickToOpen: "",
39
- tabmodalNameToOpen: "",
40
- preDefinedFunctionExecution: "",
41
- },
42
- },
43
- };
44
- export default meta;
45
- type Story = StoryObj<typeof meta>;
46
- export const Default: Story = {};
1
+ import { CtaCallout } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof CtaCallout> = {
7
+ title: "Contentful Blocks/CtaCallout",
8
+ component: CtaCallout,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component:
16
+ "Contentful CTA callout block with title, description, and optional button.",
17
+ },
18
+ },
19
+ },
20
+ args: {
21
+ title: "Call to Action",
22
+ subTitle: "Subtitle",
23
+ description: "Description text.",
24
+ background: "white",
25
+ button: {
26
+ showButtonAs: "solid",
27
+ buttonVariant: "primary_brand",
28
+ buttonLabel: "Learn More",
29
+ buttonPrefix: "",
30
+ badge: "",
31
+ badgeIcon: "",
32
+ buttonIcon: "",
33
+ buttonIconPosition: "left",
34
+ href: "",
35
+ target: "_self",
36
+ anchorId: "",
37
+ preserveQueryParameters: false,
38
+ clickToOpen: "",
39
+ tabmodalNameToOpen: "",
40
+ preDefinedFunctionExecution: "",
41
+ },
42
+ },
43
+ };
44
+ export default meta;
45
+ type Story = StoryObj<typeof meta>;
46
+ export const Default: Story = {};
@@ -1,54 +1,54 @@
1
- import React from "react";
2
- import { CtaCalloutProps, ThemeKey } from "./types";
3
-
4
- import { Text } from "@shared/components/text";
5
- import { Button } from "@shared/contentful/blocks/button";
6
-
7
- export const CtaCallout: React.FC<CtaCalloutProps> = ({
8
- title,
9
- background = "white",
10
- button,
11
- color,
12
- contentAlignment,
13
- description,
14
- descriptionAlignment,
15
- enableHeading,
16
- subTitle,
17
- maxWidth = true,
18
- }) => {
19
- const bgColorClasses: Record<ThemeKey, string> = {
20
- blue: "bg-[#07B2E2]",
21
- green: "bg-[#26B170]",
22
- yellow: "bg-[#F5FF1E]",
23
- purple: "bg-[#931D69]",
24
- white: "bg-white",
25
- navy: "bg-[#00002D]",
26
- };
27
- return (
28
- <div className={`${bgColorClasses[background]} component-container`}>
29
- <div
30
- className={`${maxWidth ? "mx-auto max-w-120" : ""} color-${color} flex flex-col ${color == "dark" ? "text-text" : "text-white"} px-5 py-16 lg:px-13 lg:py-24`}
31
- >
32
- <Text
33
- as={enableHeading ? "h1" : "h2"}
34
- className={`heading2 lg:heading1 text-${contentAlignment}`}
35
- >
36
- {title}
37
- </Text>
38
- <Text
39
- as="h3"
40
- className={`subheading3 pt-2 lg:subheading1 lg:pt-3 text-${contentAlignment}`}
41
- >
42
- {subTitle}
43
- </Text>
44
- <div className={`pt-2 text-body1 lg:pt-3 text-${descriptionAlignment}`}>
45
- {description}
46
- </div>
47
- <div className="flex justify-center pt-5 lg:pt-14">
48
- <Button {...button} />
49
- </div>
50
- </div>
51
- </div>
52
- );
53
- };
54
- export default CtaCallout;
1
+ import React from "react";
2
+ import { CtaCalloutProps, ThemeKey } from "./types";
3
+
4
+ import { Text } from "@shared/components/text";
5
+ import { Button } from "@shared/contentful/blocks/button";
6
+
7
+ export const CtaCallout: React.FC<CtaCalloutProps> = ({
8
+ title,
9
+ background = "white",
10
+ button,
11
+ color,
12
+ contentAlignment,
13
+ description,
14
+ descriptionAlignment,
15
+ enableHeading,
16
+ subTitle,
17
+ maxWidth = true,
18
+ }) => {
19
+ const bgColorClasses: Record<ThemeKey, string> = {
20
+ blue: "bg-[#07B2E2]",
21
+ green: "bg-[#26B170]",
22
+ yellow: "bg-[#F5FF1E]",
23
+ purple: "bg-[#931D69]",
24
+ white: "bg-white",
25
+ navy: "bg-[#00002D]",
26
+ };
27
+ return (
28
+ <div className={`${bgColorClasses[background]} component-container`}>
29
+ <div
30
+ className={`${maxWidth ? "mx-auto max-w-120" : ""} color-${color} flex flex-col ${color == "dark" ? "text-text" : "text-white"} px-5 py-16 lg:px-13 lg:py-24`}
31
+ >
32
+ <Text
33
+ as={enableHeading ? "h1" : "h2"}
34
+ className={`heading2 lg:heading1 text-${contentAlignment}`}
35
+ >
36
+ {title}
37
+ </Text>
38
+ <Text
39
+ as="h3"
40
+ className={`subheading3 pt-2 lg:subheading1 lg:pt-3 text-${contentAlignment}`}
41
+ >
42
+ {subTitle}
43
+ </Text>
44
+ <div className={`pt-2 text-body1 lg:pt-3 text-${descriptionAlignment}`}>
45
+ {description}
46
+ </div>
47
+ <div className="flex justify-center pt-5 lg:pt-14">
48
+ <Button {...button} />
49
+ </div>
50
+ </div>
51
+ </div>
52
+ );
53
+ };
54
+ export default CtaCallout;
@@ -1,22 +1,22 @@
1
- import React from "react";
2
-
3
- export type CtaCalloutProps = {
4
- title?: string;
5
- subTitle?: string;
6
- enableHeading?: boolean;
7
- color?: "dark" | "light";
8
- background?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
9
- description?: React.ReactNode;
10
- descriptionAlignment?: "center" | "left" | "right";
11
- contentAlignment?: "center" | "left" | "right";
12
- button?: any;
13
- maxWidth?: boolean;
14
- };
15
-
16
- export type ThemeKey =
17
- | "blue"
18
- | "green"
19
- | "yellow"
20
- | "purple"
21
- | "white"
22
- | "navy";
1
+ import React from "react";
2
+
3
+ export type CtaCalloutProps = {
4
+ title?: string;
5
+ subTitle?: string;
6
+ enableHeading?: boolean;
7
+ color?: "dark" | "light";
8
+ background?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
9
+ description?: React.ReactNode;
10
+ descriptionAlignment?: "center" | "left" | "right";
11
+ contentAlignment?: "center" | "left" | "right";
12
+ button?: any;
13
+ maxWidth?: boolean;
14
+ };
15
+
16
+ export type ThemeKey =
17
+ | "blue"
18
+ | "green"
19
+ | "yellow"
20
+ | "purple"
21
+ | "white"
22
+ | "navy";
@@ -1,34 +1,34 @@
1
- import { FloatingBanner } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof FloatingBanner> = {
7
- title: "Contentful Blocks/FloatingBanner",
8
- component: FloatingBanner,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful floating banner block.",
16
- },
17
- },
18
- },
19
- args: {
20
- title: "test",
21
- enableHeading: false,
22
- subtitle: "Test",
23
- icon: "https://images.ctfassets.net/lefc0joykfg0/xt7XD2oCXK79H8pyMyMb8/18aead59bc97d624b5bd91b2f9f04352/banner_call_icon.svg",
24
- description: <p>test</p>,
25
- cta: null,
26
- disclaimer: <p>test</p>,
27
- background: "green",
28
- color: "light",
29
- maxWidth: true,
30
- },
31
- };
32
- export default meta;
33
- type Story = StoryObj<typeof meta>;
34
- export const Default: Story = {};
1
+ import { FloatingBanner } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof FloatingBanner> = {
7
+ title: "Contentful Blocks/FloatingBanner",
8
+ component: FloatingBanner,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful floating banner block.",
16
+ },
17
+ },
18
+ },
19
+ args: {
20
+ title: "test",
21
+ enableHeading: false,
22
+ subtitle: "Test",
23
+ icon: "https://images.ctfassets.net/lefc0joykfg0/xt7XD2oCXK79H8pyMyMb8/18aead59bc97d624b5bd91b2f9f04352/banner_call_icon.svg",
24
+ description: <p>test</p>,
25
+ cta: null,
26
+ disclaimer: <p>test</p>,
27
+ background: "green",
28
+ color: "light",
29
+ maxWidth: true,
30
+ },
31
+ };
32
+ export default meta;
33
+ type Story = StoryObj<typeof meta>;
34
+ export const Default: Story = {};