@windstream/react-shared-components 0.1.31 → 0.1.33

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 (175) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.d.ts +14 -2
  3. package/dist/contentful/index.esm.js +3 -3
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +3 -3
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +4 -4
  8. package/dist/index.d.ts +4 -4
  9. package/dist/index.esm.js +1 -1
  10. package/dist/index.esm.js.map +1 -1
  11. package/dist/index.js +1 -1
  12. package/dist/index.js.map +1 -1
  13. package/dist/styles.css +1 -1
  14. package/dist/utils/index.d.ts +5 -1
  15. package/dist/utils/index.esm.js +1 -1
  16. package/dist/utils/index.esm.js.map +1 -1
  17. package/dist/utils/index.js +1 -1
  18. package/dist/utils/index.js.map +1 -1
  19. package/package.json +182 -182
  20. package/src/components/accordion/Accordion.stories.tsx +230 -230
  21. package/src/components/accordion/index.tsx +70 -70
  22. package/src/components/accordion/types.ts +12 -12
  23. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  24. package/src/components/alert-card/index.tsx +41 -41
  25. package/src/components/alert-card/types.ts +13 -13
  26. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  27. package/src/components/brand-button/helpers.ts +35 -35
  28. package/src/components/brand-button/index.tsx +114 -115
  29. package/src/components/brand-button/types.ts +37 -37
  30. package/src/components/button/Button.stories.tsx +108 -108
  31. package/src/components/button/index.tsx +27 -27
  32. package/src/components/button/types.ts +14 -14
  33. package/src/components/call-button/CallButton.stories.tsx +324 -324
  34. package/src/components/call-button/index.tsx +86 -86
  35. package/src/components/call-button/types.ts +11 -11
  36. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  37. package/src/components/checkbox/index.tsx +197 -197
  38. package/src/components/checkbox/types.ts +27 -27
  39. package/src/components/checklist/Checklist.stories.tsx +150 -150
  40. package/src/components/checklist/index.tsx +63 -61
  41. package/src/components/checklist/types.ts +18 -17
  42. package/src/components/collapse/Collapse.stories.tsx +255 -255
  43. package/src/components/collapse/index.tsx +46 -46
  44. package/src/components/collapse/types.ts +6 -6
  45. package/src/components/divider/Divider.stories.tsx +205 -205
  46. package/src/components/divider/index.tsx +22 -22
  47. package/src/components/divider/type.ts +3 -3
  48. package/src/components/image/Image.stories.tsx +113 -113
  49. package/src/components/image/index.tsx +25 -25
  50. package/src/components/image/types.ts +40 -40
  51. package/src/components/input/Input.stories.tsx +325 -325
  52. package/src/components/input/index.tsx +177 -177
  53. package/src/components/input/types.ts +37 -37
  54. package/src/components/link/Link.stories.tsx +163 -163
  55. package/src/components/link/types.ts +25 -25
  56. package/src/components/list/List.stories.tsx +272 -272
  57. package/src/components/list/index.tsx +88 -88
  58. package/src/components/list/list-item/index.tsx +38 -38
  59. package/src/components/list/list-item/types.ts +13 -13
  60. package/src/components/list/types.ts +29 -29
  61. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  62. package/src/components/material-icon/constants.ts +98 -98
  63. package/src/components/material-icon/index.tsx +47 -47
  64. package/src/components/material-icon/types.ts +31 -31
  65. package/src/components/modal/Modal.stories.tsx +171 -171
  66. package/src/components/modal/index.tsx +164 -164
  67. package/src/components/modal/types.ts +24 -24
  68. package/src/components/next-image/index.tsx +54 -54
  69. package/src/components/next-image/types.ts +1 -1
  70. package/src/components/pagination/index.tsx +100 -100
  71. package/src/components/pagination/types.ts +6 -6
  72. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  73. package/src/components/radio-button/index.tsx +75 -75
  74. package/src/components/radio-button/types.ts +21 -21
  75. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  76. package/src/components/see-more/index.tsx +44 -44
  77. package/src/components/see-more/types.ts +4 -4
  78. package/src/components/select/Select.stories.tsx +411 -411
  79. package/src/components/select/index.tsx +155 -155
  80. package/src/components/select/types.ts +36 -36
  81. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  82. package/src/components/select-plan-button/index.tsx +59 -59
  83. package/src/components/select-plan-button/types.ts +17 -17
  84. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  85. package/src/components/skeleton/index.tsx +61 -61
  86. package/src/components/skeleton/types.ts +4 -4
  87. package/src/components/spinner/Spinner.stories.tsx +335 -335
  88. package/src/components/spinner/index.tsx +44 -44
  89. package/src/components/spinner/types.ts +5 -5
  90. package/src/components/text/Text.stories.tsx +321 -321
  91. package/src/components/text/index.tsx +25 -25
  92. package/src/components/text/types.ts +45 -45
  93. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  94. package/src/components/tooltip/index.tsx +74 -74
  95. package/src/components/tooltip/types.ts +7 -7
  96. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  97. package/src/components/view-cart-button/index.tsx +42 -42
  98. package/src/components/view-cart-button/types.ts +5 -5
  99. package/src/contentful/blocks/accordion/index.tsx +62 -62
  100. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  101. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  102. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +65 -65
  103. package/src/contentful/blocks/anchored-bottom-banner/types.ts +9 -9
  104. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  105. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  106. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  107. package/src/contentful/blocks/button/index.tsx +129 -129
  108. package/src/contentful/blocks/button/types.ts +39 -39
  109. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  110. package/src/contentful/blocks/callout/index.tsx +88 -88
  111. package/src/contentful/blocks/callout/types.ts +15 -15
  112. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  113. package/src/contentful/blocks/cards/blog-card/index.tsx +110 -110
  114. package/src/contentful/blocks/cards/blog-card/types.ts +18 -18
  115. package/src/contentful/blocks/cards/index.tsx +13 -13
  116. package/src/contentful/blocks/cards/product-card/index.tsx +252 -252
  117. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  118. package/src/contentful/blocks/cards/simple-card/index.tsx +89 -89
  119. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  120. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  121. package/src/contentful/blocks/cards/types.ts +1 -1
  122. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  123. package/src/contentful/blocks/carousel/helper.tsx +440 -440
  124. package/src/contentful/blocks/carousel/index.tsx +85 -85
  125. package/src/contentful/blocks/carousel/types.ts +144 -144
  126. package/src/contentful/blocks/cookiebanner/index.tsx +146 -0
  127. package/src/contentful/blocks/cookiebanner/type.ts +7 -0
  128. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  129. package/src/contentful/blocks/cta-callout/index.tsx +60 -60
  130. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  131. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  132. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  133. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  134. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  135. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  136. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  137. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  138. package/src/contentful/blocks/footer/index.tsx +90 -90
  139. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  140. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  141. package/src/contentful/blocks/image-promo-bar/index.tsx +14 -12
  142. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  143. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  144. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  145. package/src/contentful/blocks/modal/constants.ts +53 -53
  146. package/src/contentful/blocks/modal/types.ts +12 -12
  147. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +113 -113
  148. package/src/contentful/blocks/navigation/index.tsx +394 -394
  149. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  150. package/src/contentful/blocks/navigation/types.ts +41 -41
  151. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  152. package/src/contentful/blocks/primary-hero/index.tsx +234 -234
  153. package/src/contentful/blocks/primary-hero/types.ts +35 -35
  154. package/src/contentful/blocks/search-block/index.tsx +90 -90
  155. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  156. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  157. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  158. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  159. package/src/contentful/blocks/text/index.tsx +12 -12
  160. package/src/contentful/blocks/text/types.ts +1 -1
  161. package/src/contentful/index.ts +81 -78
  162. package/src/hooks/use-body-scroll-lock.ts +34 -34
  163. package/src/hooks/use-carousel-swipe.ts +264 -264
  164. package/src/hooks/use-outside-click.ts +17 -17
  165. package/src/index.ts +101 -101
  166. package/src/next/index.ts +5 -5
  167. package/src/setupTests.ts +46 -46
  168. package/src/stories/DocsTemplate.tsx +24 -24
  169. package/src/styles/globals.css +343 -343
  170. package/src/types/global.d.ts +9 -9
  171. package/src/types/micro-components.ts +99 -99
  172. package/src/types/utm.ts +49 -49
  173. package/src/utils/cookie.ts +80 -58
  174. package/src/utils/index.ts +65 -65
  175. package/src/utils/utm.ts +221 -221
@@ -1,42 +1,42 @@
1
- import { Button } from "../button";
2
- import { MaterialIcon } from "../material-icon";
3
- import { Text } from "../text";
4
- import { ViewCartButtonProps } from "./types";
5
-
6
- import { cx } from "@shared/utils";
7
-
8
- const baseClasses =
9
- "btn-medium rounded-button pl-15 pr-15 inline-flex gap-2 items-center justify-center outline-none focus:ring-2 focus:ring-offset-2 cursor-pointer transition-colors duration-200 align-top border-2 border-border-secondary-on-bg-fill bg-bg text-text focus:ring-bg-surface-inverse";
10
- export const ViewCartButton: React.FC<ViewCartButtonProps> = props => {
11
- const { cartTotalText, onClick, isOpen, ...rest } = props;
12
- return (
13
- <Button
14
- className={cx(
15
- baseClasses,
16
- "btn-small w-full border-border pl-6 pr-4 md:btn-medium"
17
- )}
18
- onClick={onClick}
19
- {...rest}
20
- >
21
- <div className="flex w-full items-center justify-center gap-2">
22
- <div className="flex flex-col items-center justify-center">
23
- <Text className="label4 -mb-1 text-text">View cart</Text>
24
- <Text className="label3 text-text md:label1" data-testid="cart-total">
25
- {cartTotalText}
26
- </Text>
27
- </div>
28
- <MaterialIcon
29
- name="keyboard_arrow_up"
30
- size={24}
31
- fill={0}
32
- className={cx(
33
- "h-6 w-6 transition-transform",
34
- isOpen ? "rotate-180" : "rotate-0"
35
- )}
36
- />
37
- </div>
38
- </Button>
39
- );
40
- };
41
-
42
- export type { ViewCartButtonProps } from "./types";
1
+ import { Button } from "../button";
2
+ import { MaterialIcon } from "../material-icon";
3
+ import { Text } from "../text";
4
+ import { ViewCartButtonProps } from "./types";
5
+
6
+ import { cx } from "@shared/utils";
7
+
8
+ const baseClasses =
9
+ "btn-medium rounded-button pl-15 pr-15 inline-flex gap-2 items-center justify-center outline-none focus:ring-2 focus:ring-offset-2 cursor-pointer transition-colors duration-200 align-top border-2 border-border-secondary-on-bg-fill bg-bg text-text focus:ring-bg-surface-inverse";
10
+ export const ViewCartButton: React.FC<ViewCartButtonProps> = props => {
11
+ const { cartTotalText, onClick, isOpen, ...rest } = props;
12
+ return (
13
+ <Button
14
+ className={cx(
15
+ baseClasses,
16
+ "btn-small w-full border-border pl-6 pr-4 md:btn-medium"
17
+ )}
18
+ onClick={onClick}
19
+ {...rest}
20
+ >
21
+ <div className="flex w-full items-center justify-center gap-2">
22
+ <div className="flex flex-col items-center justify-center">
23
+ <Text className="label4 -mb-1 text-text">View cart</Text>
24
+ <Text className="label3 text-text md:label1" data-testid="cart-total">
25
+ {cartTotalText}
26
+ </Text>
27
+ </div>
28
+ <MaterialIcon
29
+ name="keyboard_arrow_up"
30
+ size={24}
31
+ fill={0}
32
+ className={cx(
33
+ "h-6 w-6 transition-transform",
34
+ isOpen ? "rotate-180" : "rotate-0"
35
+ )}
36
+ />
37
+ </div>
38
+ </Button>
39
+ );
40
+ };
41
+
42
+ export type { ViewCartButtonProps } from "./types";
@@ -1,5 +1,5 @@
1
- export type ViewCartButtonProps = {
2
- cartTotalText: string;
3
- onClick: () => void;
4
- isOpen: boolean;
5
- } & React.ButtonHTMLAttributes<HTMLButtonElement>;
1
+ export type ViewCartButtonProps = {
2
+ cartTotalText: string;
3
+ onClick: () => void;
4
+ isOpen: boolean;
5
+ } & React.ButtonHTMLAttributes<HTMLButtonElement>;
@@ -1,62 +1,62 @@
1
- import React from "react";
2
- import { AccordionProps, ThemeKey } from "./types";
3
-
4
- import { Accordion as AccordionComponent } from "@shared/components/accordion";
5
- import { Divider } from "@shared/components/divider";
6
- import { Text } from "@shared/components/text";
7
-
8
- export const Accordion: React.FC<AccordionProps> = ({
9
- items,
10
- title,
11
- background = "white",
12
- enableHeading = false,
13
- maxWidth = true,
14
- }) => {
15
- const bgColorClasses: Record<ThemeKey, string> = {
16
- blue: "bg-[#07B2E2]",
17
- green: "bg-[#26B170]",
18
- yellow: "bg-[#F5FF1E]",
19
- purple: "bg-[#931D69]",
20
- white: "bg-white",
21
- navy: "bg-[#00002D]",
22
- };
23
- return (
24
- <div className={`${bgColorClasses[background]} component-container`}>
25
- <div
26
- className={`${maxWidth ? "max-w-120 xl:mx-auto" : ""} mx-5 my-8 lg:mx-20 lg:my-18`}
27
- >
28
- <div>
29
- <Text
30
- as={enableHeading ? "h1" : "h2"}
31
- className="heading2 text-left text-text md:heading1 lg:text-center"
32
- >
33
- {title}
34
- </Text>
35
- </div>
36
- <div className="question-answer-section mt-10 lg:mt-16">
37
- {items?.map((item: any, index: number) => (
38
- <div key={`item-${index}`}>
39
- <AccordionComponent
40
- title={item.title}
41
- containerClassName="border-none flex flex-col gap-6"
42
- buttonClassName="p-0 label1"
43
- titleClassName="label3 md:label1 text-text"
44
- className="p-0 text-text"
45
- iconClassName="text-icon"
46
- borderRadiusNone={true}
47
- openOnlyOnDesktop={false}
48
- >
49
- <Text as="div">{item.description}</Text>
50
- </AccordionComponent>
51
- {index < items.length - 1 && (
52
- <Divider key={`divider-${index}`} className="my-6 md:my-10" />
53
- )}
54
- </div>
55
- ))}
56
- </div>
57
- </div>
58
- </div>
59
- );
60
- };
61
-
62
- export default Accordion;
1
+ import React from "react";
2
+ import { AccordionProps, ThemeKey } from "./types";
3
+
4
+ import { Accordion as AccordionComponent } from "@shared/components/accordion";
5
+ import { Divider } from "@shared/components/divider";
6
+ import { Text } from "@shared/components/text";
7
+
8
+ export const Accordion: React.FC<AccordionProps> = ({
9
+ items,
10
+ title,
11
+ background = "white",
12
+ enableHeading = false,
13
+ maxWidth = true,
14
+ }) => {
15
+ const bgColorClasses: Record<ThemeKey, string> = {
16
+ blue: "bg-[#07B2E2]",
17
+ green: "bg-[#26B170]",
18
+ yellow: "bg-[#F5FF1E]",
19
+ purple: "bg-[#931D69]",
20
+ white: "bg-white",
21
+ navy: "bg-[#00002D]",
22
+ };
23
+ return (
24
+ <div className={`${bgColorClasses[background]} component-container`}>
25
+ <div
26
+ className={`${maxWidth ? "max-w-120 xl:mx-auto" : ""} mx-5 my-8 lg:mx-20 lg:my-18`}
27
+ >
28
+ <div>
29
+ <Text
30
+ as={enableHeading ? "h1" : "h2"}
31
+ className="heading2 text-left text-text md:heading1 lg:text-center"
32
+ >
33
+ {title}
34
+ </Text>
35
+ </div>
36
+ <div className="question-answer-section mt-10 lg:mt-16">
37
+ {items?.map((item: any, index: number) => (
38
+ <div key={`item-${index}`}>
39
+ <AccordionComponent
40
+ title={item.title}
41
+ containerClassName="border-none flex flex-col gap-6"
42
+ buttonClassName="p-0 label1"
43
+ titleClassName="label3 md:label1 text-text"
44
+ className="p-0 text-text"
45
+ iconClassName="text-icon"
46
+ borderRadiusNone={true}
47
+ openOnlyOnDesktop={false}
48
+ >
49
+ <Text as="div">{item.description}</Text>
50
+ </AccordionComponent>
51
+ {index < items.length - 1 && (
52
+ <Divider key={`divider-${index}`} className="my-6 md:my-10" />
53
+ )}
54
+ </div>
55
+ ))}
56
+ </div>
57
+ </div>
58
+ </div>
59
+ );
60
+ };
61
+
62
+ export default Accordion;
@@ -1,52 +1,52 @@
1
- import { FC } from "react";
2
- import { AddressInputBannerProps } from "./types";
3
-
4
- import { Text } from "@shared/components/text";
5
- import { cx } from "@shared/utils";
6
-
7
- const variantStyles: Record<string, { bg: string; text: string }> = {
8
- yellow: { bg: "bg-fill-brand-accent", text: "text" },
9
- white: { bg: "bg-white", text: "text" },
10
- navy: { bg: "bg-bg-fill-inverse", text: "text-inverse" },
11
- green: { bg: "bg-border-success", text: "text-inverse" },
12
- };
13
-
14
- export const AddressInputBanner: FC<AddressInputBannerProps> = props => {
15
- const {
16
- title,
17
- variant = "yellow",
18
- cta,
19
- navHeight,
20
- isVisible,
21
- renderCheckPlans,
22
- } = props;
23
-
24
- const style = variantStyles[variant?.toLowerCase()] || variantStyles.yellow;
25
-
26
- if (!isVisible) return null;
27
-
28
- const ctaLabel = cta?.buttonLabel || "Check plans";
29
- const renderedCheckPlans = renderCheckPlans?.({
30
- ctaText: ctaLabel,
31
- buttonVariant: cta?.buttonVariant,
32
- showButtonAs: "solid",
33
- cta: cta,
34
- });
35
-
36
- return (
37
- <div
38
- style={{
39
- top: `${navHeight}px`,
40
- }}
41
- className={cx(
42
- `fixed left-0 right-0 z-[999] w-full shadow-lg transition-all duration-300 bg-${style.bg} text-${style.text} `,
43
- "flex flex-col items-center justify-center gap-3 p-[10px] lg:flex-row lg:gap-8 lg:px-8 lg:py-[10px]"
44
- )}
45
- >
46
- <Text className="w-full whitespace-nowrap text-center text-label1 font-black lg:w-auto lg:text-left">
47
- {title}
48
- </Text>
49
- {renderedCheckPlans}
50
- </div>
51
- );
52
- };
1
+ import { FC } from "react";
2
+ import { AddressInputBannerProps } from "./types";
3
+
4
+ import { Text } from "@shared/components/text";
5
+ import { cx } from "@shared/utils";
6
+
7
+ const variantStyles: Record<string, { bg: string; text: string }> = {
8
+ yellow: { bg: "bg-fill-brand-accent", text: "text" },
9
+ white: { bg: "bg-white", text: "text" },
10
+ navy: { bg: "bg-bg-fill-inverse", text: "text-inverse" },
11
+ green: { bg: "bg-border-success", text: "text-inverse" },
12
+ };
13
+
14
+ export const AddressInputBanner: FC<AddressInputBannerProps> = props => {
15
+ const {
16
+ title,
17
+ variant = "yellow",
18
+ cta,
19
+ navHeight,
20
+ isVisible,
21
+ renderCheckPlans,
22
+ } = props;
23
+
24
+ const style = variantStyles[variant?.toLowerCase()] || variantStyles.yellow;
25
+
26
+ if (!isVisible) return null;
27
+
28
+ const ctaLabel = cta?.buttonLabel || "Check plans";
29
+ const renderedCheckPlans = renderCheckPlans?.({
30
+ ctaText: ctaLabel,
31
+ buttonVariant: cta?.buttonVariant,
32
+ showButtonAs: "solid",
33
+ cta: cta,
34
+ });
35
+
36
+ return (
37
+ <div
38
+ style={{
39
+ top: `${navHeight}px`,
40
+ }}
41
+ className={cx(
42
+ `sticky left-0 right-0 z-[89] w-full shadow-drop transition-all duration-200 lg:fixed bg-${style.bg} text-${style.text}`,
43
+ "flex flex-col items-center justify-center gap-3 p-[10px] lg:flex-row lg:gap-8 lg:px-6 lg:py-[10px]"
44
+ )}
45
+ >
46
+ <Text className="label3 w-full text-center text-text lg:w-auto lg:text-left">
47
+ {title}
48
+ </Text>
49
+ {renderedCheckPlans}
50
+ </div>
51
+ );
52
+ };
@@ -1,14 +1,14 @@
1
- import React from "react";
2
-
3
- import { ButtonProps } from "@shared/contentful/blocks/button/types";
4
- import { CheckPlansProps } from "@shared/types/micro-components";
5
-
6
- export interface AddressInputBannerProps {
7
- entryName?: string;
8
- title: string;
9
- variant?: string;
10
- cta?: ButtonProps;
11
- navHeight?: number;
12
- isVisible?: boolean;
13
- renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
14
- }
1
+ import React from "react";
2
+
3
+ import { ButtonProps } from "@shared/contentful/blocks/button/types";
4
+ import { CheckPlansProps } from "@shared/types/micro-components";
5
+
6
+ export interface AddressInputBannerProps {
7
+ entryName?: string;
8
+ title: string;
9
+ variant?: string;
10
+ cta?: ButtonProps;
11
+ navHeight?: number;
12
+ isVisible?: boolean;
13
+ renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
14
+ }
@@ -1,65 +1,65 @@
1
- import React from "react";
2
- import { AnchoredBottomBannerProps } from "./types";
3
- import Link from "next/link";
4
-
5
- import { MaterialIcon } from "@shared/components/material-icon";
6
-
7
- export const AnchoredBottomBanner: React.FC<AnchoredBottomBannerProps> = ({
8
- ctaSuffixText,
9
- backgroundColor,
10
- iconName,
11
- boxShadow,
12
- ctaButtonLabel,
13
- ctaButtonLink,
14
- ctaButtonTarget,
15
- }) => {
16
- const backGroundColorClasses = {
17
- navy: "bg-bg-fill-inverse",
18
- green: "bg-bg-fill-success",
19
- blue: "bg-bg-fill-brand-supporting",
20
- purple: "bg-bg-fill-brand-tertiary",
21
- yellow: "bg-bg-fill-brand-accent",
22
- };
23
-
24
- const bgClass = backgroundColor
25
- ? backGroundColorClasses[backgroundColor]
26
- : "bg-bg-fill-brand-accent";
27
-
28
- const isYellow = backgroundColor === "yellow" || !backgroundColor;
29
- const textColorClass = isYellow ? "text-text-primary" : "text-white";
30
-
31
- return (
32
- <div
33
- className={`fixed bottom-0 left-0 right-0 z-[30] flex w-full items-center justify-center px-4 py-3 transition-all duration-300 ${bgClass} ${
34
- boxShadow ? boxShadow : "shadow-[0_-4px_10px_rgba(0,0,0,0.1)]"
35
- }`}
36
- >
37
- <Link
38
- href={ctaButtonLink || "#"}
39
- target={ctaButtonTarget || "_self"}
40
- className="max-w-screen-xl w-full transition-all"
41
- >
42
- <div className="flex flex-col items-center justify-center gap-1 text-center font-black">
43
- <div
44
- className={`${textColorClass} break-words text-body1 font-black leading-snug md:text-[18px]`}
45
- >
46
- {iconName && (
47
- <MaterialIcon
48
- name={
49
- iconName as React.ComponentProps<typeof MaterialIcon>["name"]
50
- }
51
- size={24}
52
- fill={1}
53
- className={`${textColorClass} align-text-bottom`}
54
- />
55
- )}
56
- {ctaButtonLabel && ctaButtonLabel}{" "}
57
- {ctaSuffixText && <span className="ml-0.5">{ctaSuffixText}</span>}
58
- </div>
59
- </div>
60
- </Link>
61
- </div>
62
- );
63
- };
64
-
65
- export default AnchoredBottomBanner;
1
+ import React from "react";
2
+ import { AnchoredBottomBannerProps } from "./types";
3
+ import Link from "next/link";
4
+
5
+ import { MaterialIcon } from "@shared/components/material-icon";
6
+
7
+ export const AnchoredBottomBanner: React.FC<AnchoredBottomBannerProps> = ({
8
+ ctaSuffixText,
9
+ backgroundColor,
10
+ iconName,
11
+ boxShadow,
12
+ ctaButtonLabel,
13
+ ctaButtonLink,
14
+ ctaButtonTarget,
15
+ }) => {
16
+ const backGroundColorClasses = {
17
+ navy: "bg-bg-fill-inverse",
18
+ green: "bg-bg-fill-success",
19
+ blue: "bg-bg-fill-brand-supporting",
20
+ purple: "bg-bg-fill-brand-tertiary",
21
+ yellow: "bg-bg-fill-brand-accent",
22
+ };
23
+
24
+ const bgClass = backgroundColor
25
+ ? backGroundColorClasses[backgroundColor]
26
+ : "bg-bg-fill-brand-accent";
27
+
28
+ const isYellow = backgroundColor === "yellow" || !backgroundColor;
29
+ const textColorClass = isYellow ? "text-text-primary" : "text-white";
30
+
31
+ return (
32
+ <div
33
+ className={`fixed bottom-0 left-0 right-0 z-[30] flex w-full items-center justify-center px-4 py-3 transition-all duration-300 ${bgClass} ${
34
+ boxShadow ? boxShadow : "shadow-[0_-4px_10px_rgba(0,0,0,0.1)]"
35
+ }`}
36
+ >
37
+ <Link
38
+ href={ctaButtonLink || "#"}
39
+ target={ctaButtonTarget || "_self"}
40
+ className="max-w-screen-xl w-full transition-all"
41
+ >
42
+ <div className="flex flex-col items-center justify-center gap-1 text-center font-black">
43
+ <div
44
+ className={`${textColorClass} break-words text-body1 font-black leading-snug md:text-[18px]`}
45
+ >
46
+ {iconName && (
47
+ <MaterialIcon
48
+ name={
49
+ iconName as React.ComponentProps<typeof MaterialIcon>["name"]
50
+ }
51
+ size={24}
52
+ fill={1}
53
+ className={`${textColorClass} align-text-bottom`}
54
+ />
55
+ )}
56
+ {ctaButtonLabel && ctaButtonLabel}{" "}
57
+ {ctaSuffixText && <span className="ml-0.5">{ctaSuffixText}</span>}
58
+ </div>
59
+ </div>
60
+ </Link>
61
+ </div>
62
+ );
63
+ };
64
+
65
+ export default AnchoredBottomBanner;
@@ -1,9 +1,9 @@
1
- export interface AnchoredBottomBannerProps {
2
- ctaSuffixText?: string;
3
- backgroundColor?: "navy" | "yellow" | "green" | "purple" | "blue";
4
- iconName?: string;
5
- boxShadow?: boolean;
6
- ctaButtonLabel?: string;
7
- ctaButtonLink?: string;
8
- ctaButtonTarget?: string;
9
- }
1
+ export interface AnchoredBottomBannerProps {
2
+ ctaSuffixText?: string;
3
+ backgroundColor?: "navy" | "yellow" | "green" | "purple" | "blue";
4
+ iconName?: string;
5
+ boxShadow?: boolean;
6
+ ctaButtonLabel?: string;
7
+ ctaButtonLink?: string;
8
+ ctaButtonTarget?: string;
9
+ }