@windstream/react-shared-components 0.0.46 → 0.0.48

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 (133) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.d.ts +6 -1
  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 +2 -2
  8. package/dist/index.js.map +1 -1
  9. package/dist/styles.css +1 -1
  10. package/package.json +175 -175
  11. package/src/components/accordion/Accordion.stories.tsx +230 -230
  12. package/src/components/accordion/index.tsx +49 -49
  13. package/src/components/accordion/types.ts +9 -9
  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 +79 -79
  26. package/src/components/call-button/types.ts +10 -10
  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/checklist/index.tsx +39 -39
  32. package/src/components/checklist/types.ts +6 -6
  33. package/src/components/collapse/Collapse.stories.tsx +255 -255
  34. package/src/components/collapse/index.tsx +46 -46
  35. package/src/components/collapse/types.ts +6 -6
  36. package/src/components/divider/Divider.stories.tsx +205 -205
  37. package/src/components/divider/index.tsx +22 -22
  38. package/src/components/divider/type.ts +3 -3
  39. package/src/components/image/Image.stories.tsx +113 -113
  40. package/src/components/image/index.tsx +25 -25
  41. package/src/components/image/types.ts +40 -40
  42. package/src/components/input/Input.stories.tsx +325 -325
  43. package/src/components/input/index.tsx +177 -177
  44. package/src/components/input/types.ts +37 -37
  45. package/src/components/link/Link.stories.tsx +163 -163
  46. package/src/components/link/index.tsx +97 -97
  47. package/src/components/link/types.ts +25 -25
  48. package/src/components/list/List.stories.tsx +272 -272
  49. package/src/components/list/index.tsx +88 -88
  50. package/src/components/list/list-item/index.tsx +38 -38
  51. package/src/components/list/list-item/types.ts +13 -13
  52. package/src/components/list/types.ts +29 -29
  53. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  54. package/src/components/material-icon/constants.ts +96 -96
  55. package/src/components/material-icon/index.tsx +44 -44
  56. package/src/components/material-icon/types.ts +31 -31
  57. package/src/components/modal/Modal.stories.tsx +171 -171
  58. package/src/components/modal/index.tsx +164 -164
  59. package/src/components/modal/types.ts +24 -24
  60. package/src/components/next-image/index.tsx +18 -18
  61. package/src/components/next-image/types.ts +1 -1
  62. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  63. package/src/components/radio-button/index.tsx +75 -75
  64. package/src/components/radio-button/types.ts +21 -21
  65. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  66. package/src/components/see-more/index.tsx +44 -44
  67. package/src/components/see-more/types.ts +4 -4
  68. package/src/components/select/Select.stories.tsx +411 -411
  69. package/src/components/select/index.tsx +150 -150
  70. package/src/components/select/types.ts +35 -35
  71. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +168 -168
  72. package/src/components/select-plan-button/index.tsx +29 -29
  73. package/src/components/select-plan-button/types.ts +4 -4
  74. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  75. package/src/components/skeleton/index.tsx +61 -61
  76. package/src/components/skeleton/types.ts +4 -4
  77. package/src/components/spinner/Spinner.stories.tsx +335 -335
  78. package/src/components/spinner/index.tsx +44 -44
  79. package/src/components/spinner/types.ts +5 -5
  80. package/src/components/text/Text.stories.tsx +321 -321
  81. package/src/components/text/index.tsx +25 -25
  82. package/src/components/text/types.ts +45 -45
  83. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  84. package/src/components/tooltip/index.tsx +74 -74
  85. package/src/components/tooltip/types.ts +7 -7
  86. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  87. package/src/components/view-cart-button/index.tsx +44 -44
  88. package/src/components/view-cart-button/types.ts +5 -5
  89. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  90. package/src/contentful/blocks/button/index.tsx +64 -64
  91. package/src/contentful/blocks/button/types.ts +24 -24
  92. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  93. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  94. package/src/contentful/blocks/cards/index.tsx +13 -13
  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/index.tsx +13 -13
  98. package/src/contentful/blocks/carousel/types.ts +1 -1
  99. package/src/contentful/blocks/comparison-table/index.tsx +23 -2
  100. package/src/contentful/blocks/comparison-table/types.ts +6 -1
  101. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  102. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  103. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  104. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  105. package/src/contentful/blocks/floating-banner/index.tsx +102 -102
  106. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  107. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  108. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  109. package/src/contentful/blocks/image-promo-bar/types.ts +27 -27
  110. package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
  111. package/src/contentful/blocks/modal/index.tsx +12 -12
  112. package/src/contentful/blocks/modal/types.ts +1 -1
  113. package/src/contentful/blocks/navigation/Navigation.stories.tsx +23 -23
  114. package/src/contentful/blocks/navigation/index.tsx +56 -56
  115. package/src/contentful/blocks/navigation/types.ts +21 -21
  116. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  117. package/src/contentful/blocks/primary-hero/index.tsx +160 -160
  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/hooks/use-body-scroll-lock.ts +34 -34
  126. package/src/index.ts +96 -96
  127. package/src/next/index.ts +5 -5
  128. package/src/setupTests.ts +46 -46
  129. package/src/stories/DocsTemplate.tsx +24 -24
  130. package/src/styles/globals.css +307 -275
  131. package/src/types/global.d.ts +9 -9
  132. package/src/utils/index.ts +49 -49
  133. package/tailwind.config.cjs +7 -1
@@ -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" : ""} flex flex-col text-${color} 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" : ""} flex flex-col text-${color} 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?: "navy" | "white";
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?: "navy" | "white";
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: "white",
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: "white",
29
+ maxWidth: true,
30
+ },
31
+ };
32
+ export default meta;
33
+ type Story = StoryObj<typeof meta>;
34
+ export const Default: Story = {};
@@ -1,102 +1,102 @@
1
- import React from "react";
2
- import { FloatingBannerProps, ThemeKey } from "./types";
3
-
4
- import { NextImage } from "@shared/components/next-image";
5
- import { Text } from "@shared/components/text";
6
- import { Button } from "@shared/contentful/blocks/button";
7
-
8
- export const FloatingBanner: React.FC<FloatingBannerProps> = ({
9
- title,
10
- subtitle,
11
- description,
12
- disclaimer,
13
- icon,
14
- cta,
15
- background = "navy",
16
- color = "white",
17
- enableHeading,
18
- maxWidth = true,
19
- }) => {
20
- const textColorClasses: Record<ThemeKey, string> = {
21
- blue: "text-[#07B2E2]",
22
- green: "text-[#26B170]",
23
- yellow: "text-[#F5FF1E]",
24
- purple: "text-[#931D69]",
25
- white: "text-white",
26
- navy: "text-[#00002D]",
27
- };
28
-
29
- const bgColorClasses: Record<ThemeKey, string> = {
30
- blue: "bg-[#07B2E2]",
31
- green: "bg-[#26B170]",
32
- yellow: "bg-[#F5FF1E]",
33
- purple: "bg-[#931D69]",
34
- white: "bg-white",
35
- navy: "bg-[#00002D]",
36
- };
37
-
38
- return (
39
- <div className="component-container">
40
- <div
41
- className={`mx-5 my-8 lg:mx-20 lg:my-12 lg:rounded-[40px] xl:mx-auto ${maxWidth ? "max-w-120" : ""}`}
42
- >
43
- <div
44
- className={`flex flex-col rounded-[28px] px-5 py-7 lg:flex-row lg:rounded-[40px] lg:px-16 lg:py-9 ${bgColorClasses[background]} ${textColorClasses[color]} `}
45
- >
46
- {icon && (
47
- <div className="floating-banner-icon mb-5 flex justify-center lg:mb-0 lg:items-center">
48
- <div className="h-[80px] w-[80px] overflow-hidden">
49
- <NextImage
50
- width={80}
51
- height={80}
52
- alt="icon"
53
- src={icon}
54
- ></NextImage>
55
- </div>
56
- </div>
57
- )}
58
- <div className="flex flex-col justify-center lg:mx-5">
59
- {title && (
60
- <Text
61
- as={enableHeading ? "h1" : "h2"}
62
- className={`heading2 mb-3 text-center lg:w-[90%] lg:text-left`}
63
- >
64
- {title}
65
- </Text>
66
- )}
67
- {subtitle && (
68
- <Text
69
- as={"h3"}
70
- className={`heading3 mb-3 text-center lg:text-left`}
71
- >
72
- {subtitle}
73
- </Text>
74
- )}
75
- {description && (
76
- <Text
77
- as="div"
78
- className="body1 text-center lg:w-[90%] lg:text-left"
79
- >
80
- {description}
81
- </Text>
82
- )}
83
- </div>
84
- {cta && (
85
- <div className="mt-5 flex justify-center lg:mt-0 lg:w-[500px] lg:items-center">
86
- <Button {...cta}></Button>
87
- </div>
88
- )}
89
- </div>
90
- {disclaimer && (
91
- <div>
92
- <Text as="div" className="body3 mt-3 text-center">
93
- {disclaimer}
94
- </Text>
95
- </div>
96
- )}
97
- </div>
98
- </div>
99
- );
100
- };
101
-
102
- export default FloatingBanner;
1
+ import React from "react";
2
+ import { FloatingBannerProps, ThemeKey } from "./types";
3
+
4
+ import { NextImage } from "@shared/components/next-image";
5
+ import { Text } from "@shared/components/text";
6
+ import { Button } from "@shared/contentful/blocks/button";
7
+
8
+ export const FloatingBanner: React.FC<FloatingBannerProps> = ({
9
+ title,
10
+ subtitle,
11
+ description,
12
+ disclaimer,
13
+ icon,
14
+ cta,
15
+ background = "navy",
16
+ color = "white",
17
+ enableHeading,
18
+ maxWidth = true,
19
+ }) => {
20
+ const textColorClasses: Record<ThemeKey, string> = {
21
+ blue: "text-[#07B2E2]",
22
+ green: "text-[#26B170]",
23
+ yellow: "text-[#F5FF1E]",
24
+ purple: "text-[#931D69]",
25
+ white: "text-white",
26
+ navy: "text-[#00002D]",
27
+ };
28
+
29
+ const bgColorClasses: Record<ThemeKey, string> = {
30
+ blue: "bg-[#07B2E2]",
31
+ green: "bg-[#26B170]",
32
+ yellow: "bg-[#F5FF1E]",
33
+ purple: "bg-[#931D69]",
34
+ white: "bg-white",
35
+ navy: "bg-[#00002D]",
36
+ };
37
+
38
+ return (
39
+ <div className="component-container">
40
+ <div
41
+ className={`mx-5 my-8 lg:mx-20 lg:my-12 lg:rounded-[40px] xl:mx-auto ${maxWidth ? "max-w-120" : ""}`}
42
+ >
43
+ <div
44
+ className={`flex flex-col rounded-[28px] px-5 py-7 lg:flex-row lg:rounded-[40px] lg:px-16 lg:py-9 ${bgColorClasses[background]} ${textColorClasses[color]} `}
45
+ >
46
+ {icon && (
47
+ <div className="floating-banner-icon mb-5 flex justify-center lg:mb-0 lg:items-center">
48
+ <div className="h-[80px] w-[80px] overflow-hidden">
49
+ <NextImage
50
+ width={80}
51
+ height={80}
52
+ alt="icon"
53
+ src={icon}
54
+ ></NextImage>
55
+ </div>
56
+ </div>
57
+ )}
58
+ <div className="flex flex-col justify-center lg:mx-5">
59
+ {title && (
60
+ <Text
61
+ as={enableHeading ? "h1" : "h2"}
62
+ className={`heading2 mb-3 text-center lg:w-[90%] lg:text-left`}
63
+ >
64
+ {title}
65
+ </Text>
66
+ )}
67
+ {subtitle && (
68
+ <Text
69
+ as={"h3"}
70
+ className={`heading3 mb-3 text-center lg:text-left`}
71
+ >
72
+ {subtitle}
73
+ </Text>
74
+ )}
75
+ {description && (
76
+ <Text
77
+ as="div"
78
+ className="body1 text-center lg:w-[90%] lg:text-left"
79
+ >
80
+ {description}
81
+ </Text>
82
+ )}
83
+ </div>
84
+ {cta && (
85
+ <div className="mt-5 flex justify-center lg:mt-0 lg:w-[500px] lg:items-center">
86
+ <Button {...cta}></Button>
87
+ </div>
88
+ )}
89
+ </div>
90
+ {disclaimer && (
91
+ <div>
92
+ <Text as="div" className="body3 mt-3 text-center">
93
+ {disclaimer}
94
+ </Text>
95
+ </div>
96
+ )}
97
+ </div>
98
+ </div>
99
+ );
100
+ };
101
+
102
+ export default FloatingBanner;
@@ -1,22 +1,22 @@
1
- import React from "react";
2
-
3
- export type FloatingBannerProps = {
4
- title?: string;
5
- enableHeading?: boolean;
6
- subtitle?: string;
7
- icon?: string;
8
- description?: React.ReactNode;
9
- cta?: any | null;
10
- disclaimer?: React.ReactNode;
11
- background?: "green" | "navy" | "white";
12
- color?: "navy" | "white";
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 FloatingBannerProps = {
4
+ title?: string;
5
+ enableHeading?: boolean;
6
+ subtitle?: string;
7
+ icon?: string;
8
+ description?: React.ReactNode;
9
+ cta?: any | null;
10
+ disclaimer?: React.ReactNode;
11
+ background?: "green" | "navy" | "white";
12
+ color?: "navy" | "white";
13
+ maxWidth?: boolean;
14
+ };
15
+
16
+ export type ThemeKey =
17
+ | "blue"
18
+ | "green"
19
+ | "yellow"
20
+ | "purple"
21
+ | "white"
22
+ | "navy";
@@ -1,30 +1,30 @@
1
- import { Footer } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Footer> = {
7
- title: "Contentful Blocks/Footer",
8
- component: Footer,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component:
16
- "Contentful footer block with body, links, copyrights, and terms.",
17
- },
18
- },
19
- },
20
- args: {
21
- body: "Footer body content",
22
- copyrights: "Company Name",
23
- terms: "All rights reserved",
24
- links: [],
25
- bottomLinks: [],
26
- },
27
- };
28
- export default meta;
29
- type Story = StoryObj<typeof meta>;
30
- export const Default: Story = {};
1
+ import { Footer } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Footer> = {
7
+ title: "Contentful Blocks/Footer",
8
+ component: Footer,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component:
16
+ "Contentful footer block with body, links, copyrights, and terms.",
17
+ },
18
+ },
19
+ },
20
+ args: {
21
+ body: "Footer body content",
22
+ copyrights: "Company Name",
23
+ terms: "All rights reserved",
24
+ links: [],
25
+ bottomLinks: [],
26
+ },
27
+ };
28
+ export default meta;
29
+ type Story = StoryObj<typeof meta>;
30
+ export const Default: Story = {};