@windstream/react-shared-components 0.0.71 → 0.0.73

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 (138) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.d.ts +17 -6
  3. package/dist/contentful/index.esm.js +1 -1
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +1 -1
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +4 -4
  8. package/dist/index.d.ts +1 -1
  9. package/dist/index.js.map +1 -1
  10. package/dist/styles.css +1 -1
  11. package/package.json +175 -175
  12. package/src/components/accordion/Accordion.stories.tsx +230 -230
  13. package/src/components/accordion/types.ts +10 -10
  14. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  15. package/src/components/alert-card/index.tsx +32 -32
  16. package/src/components/alert-card/types.ts +9 -9
  17. package/src/components/brand-button/BrandButton.stories.tsx +219 -219
  18. package/src/components/brand-button/helpers.ts +35 -35
  19. package/src/components/brand-button/index.tsx +93 -93
  20. package/src/components/brand-button/types.ts +25 -25
  21. package/src/components/button/Button.stories.tsx +108 -108
  22. package/src/components/button/index.tsx +27 -27
  23. package/src/components/button/types.ts +14 -14
  24. package/src/components/call-button/CallButton.stories.tsx +324 -324
  25. package/src/components/call-button/index.tsx +86 -86
  26. package/src/components/call-button/types.ts +11 -11
  27. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  28. package/src/components/checkbox/index.tsx +197 -197
  29. package/src/components/checkbox/types.ts +27 -27
  30. package/src/components/checklist/Checklist.stories.tsx +150 -150
  31. package/src/components/collapse/Collapse.stories.tsx +255 -255
  32. package/src/components/collapse/index.tsx +46 -46
  33. package/src/components/collapse/types.ts +6 -6
  34. package/src/components/divider/Divider.stories.tsx +205 -205
  35. package/src/components/divider/index.tsx +22 -22
  36. package/src/components/divider/type.ts +3 -3
  37. package/src/components/image/Image.stories.tsx +113 -113
  38. package/src/components/image/index.tsx +25 -25
  39. package/src/components/image/types.ts +40 -40
  40. package/src/components/input/Input.stories.tsx +325 -325
  41. package/src/components/input/index.tsx +177 -177
  42. package/src/components/input/types.ts +37 -37
  43. package/src/components/link/Link.stories.tsx +163 -163
  44. package/src/components/link/types.ts +25 -25
  45. package/src/components/list/List.stories.tsx +272 -272
  46. package/src/components/list/index.tsx +88 -88
  47. package/src/components/list/list-item/index.tsx +38 -38
  48. package/src/components/list/list-item/types.ts +13 -13
  49. package/src/components/list/types.ts +29 -29
  50. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  51. package/src/components/material-icon/constants.ts +96 -96
  52. package/src/components/material-icon/index.tsx +44 -44
  53. package/src/components/material-icon/types.ts +31 -31
  54. package/src/components/modal/Modal.stories.tsx +171 -171
  55. package/src/components/modal/index.tsx +164 -164
  56. package/src/components/modal/types.ts +24 -24
  57. package/src/components/next-image/index.tsx +32 -32
  58. package/src/components/next-image/types.ts +1 -1
  59. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  60. package/src/components/radio-button/index.tsx +75 -75
  61. package/src/components/radio-button/types.ts +21 -21
  62. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  63. package/src/components/see-more/index.tsx +44 -44
  64. package/src/components/see-more/types.ts +4 -4
  65. package/src/components/select/Select.stories.tsx +411 -411
  66. package/src/components/select/index.tsx +150 -150
  67. package/src/components/select/types.ts +35 -35
  68. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  69. package/src/components/select-plan-button/index.tsx +31 -31
  70. package/src/components/select-plan-button/types.ts +5 -5
  71. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  72. package/src/components/skeleton/index.tsx +61 -61
  73. package/src/components/skeleton/types.ts +4 -4
  74. package/src/components/spinner/Spinner.stories.tsx +335 -335
  75. package/src/components/spinner/index.tsx +44 -44
  76. package/src/components/spinner/types.ts +5 -5
  77. package/src/components/text/Text.stories.tsx +321 -321
  78. package/src/components/text/index.tsx +25 -25
  79. package/src/components/text/types.ts +45 -45
  80. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  81. package/src/components/tooltip/index.tsx +74 -74
  82. package/src/components/tooltip/types.ts +7 -7
  83. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  84. package/src/components/view-cart-button/index.tsx +44 -44
  85. package/src/components/view-cart-button/types.ts +5 -5
  86. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  87. package/src/contentful/blocks/button/index.tsx +84 -84
  88. package/src/contentful/blocks/button/types.ts +26 -26
  89. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  90. package/src/contentful/blocks/callout/index.tsx +66 -52
  91. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  92. package/src/contentful/blocks/cards/index.tsx +13 -13
  93. package/src/contentful/blocks/cards/product-card/index.tsx +199 -199
  94. package/src/contentful/blocks/cards/product-card/types.ts +18 -18
  95. package/src/contentful/blocks/cards/simple-card/index.tsx +77 -45
  96. package/src/contentful/blocks/cards/simple-card/types.ts +31 -9
  97. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  98. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  99. package/src/contentful/blocks/cards/types.ts +1 -1
  100. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  101. package/src/contentful/blocks/carousel/helper.tsx +314 -314
  102. package/src/contentful/blocks/carousel/index.tsx +50 -50
  103. package/src/contentful/blocks/carousel/types.ts +126 -126
  104. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  105. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  106. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  107. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  108. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  109. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  110. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  111. package/src/contentful/blocks/image-promo-bar/types.ts +27 -27
  112. package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
  113. package/src/contentful/blocks/modal/index.tsx +12 -12
  114. package/src/contentful/blocks/modal/types.ts +1 -1
  115. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  116. package/src/contentful/blocks/navigation/index.tsx +380 -380
  117. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  118. package/src/contentful/blocks/navigation/types.ts +41 -41
  119. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  120. package/src/contentful/blocks/primary-hero/index.tsx +160 -160
  121. package/src/contentful/blocks/primary-hero/types.ts +30 -30
  122. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  123. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  124. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  125. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  126. package/src/contentful/blocks/text/index.tsx +12 -12
  127. package/src/contentful/blocks/text/types.ts +1 -1
  128. package/src/contentful/index.ts +57 -57
  129. package/src/hooks/use-body-scroll-lock.ts +34 -34
  130. package/src/hooks/use-outside-click.ts +17 -17
  131. package/src/index.ts +96 -96
  132. package/src/next/index.ts +5 -5
  133. package/src/setupTests.ts +46 -46
  134. package/src/stories/DocsTemplate.tsx +24 -24
  135. package/src/styles/globals.css +307 -307
  136. package/src/types/global.d.ts +9 -9
  137. package/src/types/micro-components.ts +80 -80
  138. package/src/utils/index.ts +49 -49
@@ -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 = {};