@windstream/react-shared-components 0.0.81 → 0.0.83

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 (143) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.d.ts +2 -2
  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.esm.js +1 -1
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js +1 -1
  11. package/dist/index.js.map +1 -1
  12. package/dist/styles.css +1 -1
  13. package/package.json +175 -175
  14. package/src/components/accordion/Accordion.stories.tsx +230 -230
  15. package/src/components/accordion/types.ts +10 -10
  16. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  17. package/src/components/alert-card/index.tsx +32 -32
  18. package/src/components/alert-card/types.ts +9 -9
  19. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  20. package/src/components/brand-button/helpers.ts +35 -35
  21. package/src/components/brand-button/index.tsx +115 -115
  22. package/src/components/brand-button/types.ts +37 -37
  23. package/src/components/button/Button.stories.tsx +108 -108
  24. package/src/components/button/index.tsx +27 -27
  25. package/src/components/button/types.ts +14 -14
  26. package/src/components/call-button/CallButton.stories.tsx +324 -324
  27. package/src/components/call-button/index.tsx +86 -86
  28. package/src/components/call-button/types.ts +11 -11
  29. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  30. package/src/components/checkbox/index.tsx +197 -197
  31. package/src/components/checkbox/types.ts +27 -27
  32. package/src/components/checklist/Checklist.stories.tsx +150 -150
  33. package/src/components/checklist/index.tsx +54 -53
  34. package/src/components/checklist/types.ts +9 -8
  35. package/src/components/collapse/Collapse.stories.tsx +255 -255
  36. package/src/components/collapse/index.tsx +46 -46
  37. package/src/components/collapse/types.ts +6 -6
  38. package/src/components/divider/Divider.stories.tsx +205 -205
  39. package/src/components/divider/index.tsx +22 -22
  40. package/src/components/divider/type.ts +3 -3
  41. package/src/components/image/Image.stories.tsx +113 -113
  42. package/src/components/image/index.tsx +25 -25
  43. package/src/components/image/types.ts +40 -40
  44. package/src/components/input/Input.stories.tsx +325 -325
  45. package/src/components/input/index.tsx +177 -177
  46. package/src/components/input/types.ts +37 -37
  47. package/src/components/link/Link.stories.tsx +163 -163
  48. package/src/components/link/types.ts +25 -25
  49. package/src/components/list/List.stories.tsx +272 -272
  50. package/src/components/list/index.tsx +88 -88
  51. package/src/components/list/list-item/index.tsx +38 -38
  52. package/src/components/list/list-item/types.ts +13 -13
  53. package/src/components/list/types.ts +29 -29
  54. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  55. package/src/components/material-icon/constants.ts +96 -96
  56. package/src/components/material-icon/index.tsx +44 -44
  57. package/src/components/material-icon/types.ts +31 -31
  58. package/src/components/modal/Modal.stories.tsx +171 -171
  59. package/src/components/modal/index.tsx +164 -164
  60. package/src/components/modal/types.ts +24 -24
  61. package/src/components/next-image/index.tsx +32 -32
  62. package/src/components/next-image/types.ts +1 -1
  63. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  64. package/src/components/radio-button/index.tsx +75 -75
  65. package/src/components/radio-button/types.ts +21 -21
  66. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  67. package/src/components/see-more/index.tsx +44 -44
  68. package/src/components/see-more/types.ts +4 -4
  69. package/src/components/select/Select.stories.tsx +411 -411
  70. package/src/components/select/index.tsx +150 -150
  71. package/src/components/select/types.ts +35 -35
  72. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  73. package/src/components/select-plan-button/index.tsx +31 -31
  74. package/src/components/select-plan-button/types.ts +5 -5
  75. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  76. package/src/components/skeleton/index.tsx +61 -61
  77. package/src/components/skeleton/types.ts +4 -4
  78. package/src/components/spinner/Spinner.stories.tsx +335 -335
  79. package/src/components/spinner/index.tsx +44 -44
  80. package/src/components/spinner/types.ts +5 -5
  81. package/src/components/text/Text.stories.tsx +321 -321
  82. package/src/components/text/index.tsx +25 -25
  83. package/src/components/text/types.ts +45 -45
  84. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  85. package/src/components/tooltip/index.tsx +74 -74
  86. package/src/components/tooltip/types.ts +7 -7
  87. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  88. package/src/components/view-cart-button/index.tsx +44 -44
  89. package/src/components/view-cart-button/types.ts +5 -5
  90. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  91. package/src/contentful/blocks/button/index.tsx +85 -85
  92. package/src/contentful/blocks/button/types.ts +26 -26
  93. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  94. package/src/contentful/blocks/callout/index.tsx +66 -66
  95. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  96. package/src/contentful/blocks/cards/index.tsx +13 -13
  97. package/src/contentful/blocks/cards/product-card/index.tsx +199 -199
  98. package/src/contentful/blocks/cards/product-card/types.ts +20 -18
  99. package/src/contentful/blocks/cards/simple-card/index.tsx +77 -77
  100. package/src/contentful/blocks/cards/simple-card/types.ts +31 -31
  101. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  102. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  103. package/src/contentful/blocks/cards/types.ts +1 -1
  104. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  105. package/src/contentful/blocks/carousel/helper.tsx +314 -314
  106. package/src/contentful/blocks/carousel/index.tsx +52 -50
  107. package/src/contentful/blocks/carousel/types.ts +126 -126
  108. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  109. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  110. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  111. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  112. package/src/contentful/blocks/floating-banner/index.tsx +1 -1
  113. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  114. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  115. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  116. package/src/contentful/blocks/image-promo-bar/types.ts +27 -27
  117. package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
  118. package/src/contentful/blocks/modal/index.tsx +12 -12
  119. package/src/contentful/blocks/modal/types.ts +1 -1
  120. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  121. package/src/contentful/blocks/navigation/index.tsx +380 -380
  122. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  123. package/src/contentful/blocks/navigation/types.ts +41 -41
  124. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  125. package/src/contentful/blocks/primary-hero/index.tsx +212 -212
  126. package/src/contentful/blocks/primary-hero/types.ts +30 -30
  127. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  128. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  129. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  130. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  131. package/src/contentful/blocks/text/index.tsx +12 -12
  132. package/src/contentful/blocks/text/types.ts +1 -1
  133. package/src/contentful/index.ts +57 -57
  134. package/src/hooks/use-body-scroll-lock.ts +34 -34
  135. package/src/hooks/use-outside-click.ts +17 -17
  136. package/src/index.ts +96 -96
  137. package/src/next/index.ts +5 -5
  138. package/src/setupTests.ts +46 -46
  139. package/src/stories/DocsTemplate.tsx +24 -24
  140. package/src/styles/globals.css +307 -307
  141. package/src/types/global.d.ts +9 -9
  142. package/src/types/micro-components.ts +80 -80
  143. package/src/utils/index.ts +49 -49
@@ -1,212 +1,212 @@
1
- import React from "react";
2
- import { PrimaryHeroProps } from "./types";
3
-
4
- import { Checklist } from "@shared/components/checklist";
5
- import { NextImage } from "@shared/components/next-image";
6
- import { Text } from "@shared/components/text";
7
- import { Button } from "@shared/contentful/blocks/button";
8
- import { cx } from "@shared/utils";
9
-
10
- export const PrimaryHero: React.FC<PrimaryHeroProps> = props => {
11
- const {
12
- title,
13
- showAsHeading,
14
- subTitle,
15
- primaryCta1,
16
- carouselImages,
17
- bottomLink,
18
- price,
19
- priceCallout,
20
- priceSuffix,
21
- checklist,
22
- checkPlansJSX,
23
- badgeImage,
24
- pricingDescriptionDisclaimer,
25
- secondaryCta,
26
- secondaryCtaPrefix,
27
- } = props;
28
-
29
- const bottomLinkLabel = bottomLink?.buttonLabel ?? bottomLink?.label;
30
-
31
- return (
32
- <div className="component-container p-5 lg:h-[724px] lg:p-0">
33
- <div
34
- className={cx(
35
- "primary-hero-container mx-auto flex flex-col sm:items-center sm:text-center lg:h-full lg:max-w-120 lg:flex-row lg:items-center lg:justify-between lg:gap-4 lg:px-4 lg:text-left"
36
- )}
37
- >
38
- {/* Left column: navy background, headline, body, address, button, link */}
39
- <div className={cx("relative flex flex-col text-white sm:w-[485px]")}>
40
- <div className="flex flex-col gap-5 lg:gap-6">
41
- {title && (
42
- <Text
43
- as={showAsHeading ? "h1" : "h2"}
44
- className="heading2 lg:heading1"
45
- >
46
- {title}
47
- </Text>
48
- )}
49
- {subTitle && (
50
- <Text as="p" className="subheading3 lg:subheading1">
51
- {subTitle}
52
- </Text>
53
- )}
54
-
55
- {/* price callout */}
56
- {price ? (
57
- <div className="flex">
58
- <div className="mr-2 mt-2">
59
- {priceCallout
60
- ? priceCallout.split("|").map((line, index) => (
61
- <Text key={index} as="p" className="body2">
62
- {line}
63
- </Text>
64
- ))
65
- : null}
66
- </div>
67
- <div className="flex">
68
- <Text as="p" className="subheading1 mt-2">
69
- $
70
- </Text>
71
- <Text as="p" className="subheading5">
72
- {price}
73
- </Text>
74
- {priceSuffix ? (
75
- <Text as="p" className="subheading1 mt-2">
76
- {priceSuffix}
77
- </Text>
78
- ) : null}
79
- </div>
80
- </div>
81
- ) : null}
82
-
83
- {/* checklist */}
84
- {checklist && (
85
- <Checklist
86
- listItemClassName="text-white body2"
87
- items={checklist.map(item => item.title)}
88
- />
89
- )}
90
-
91
- {/* CTA section */}
92
- <div className="flex flex-col gap-3">
93
- {/* desktop CTA */}
94
- {primaryCta1 && (
95
- <div className={cx("hidden lg:flex lg:flex-col")}>
96
- <Button {...primaryCta1} checkPlansJSX={checkPlansJSX} />
97
- </div>
98
- )}
99
-
100
- {secondaryCtaPrefix || secondaryCta ? (
101
- <div className="flex">
102
- {secondaryCtaPrefix && (
103
- <Text as="span" className="body2 mr-1">
104
- {secondaryCtaPrefix}
105
- </Text>
106
- )}
107
- {secondaryCta && (
108
- <Button
109
- linkClassName="body2 text-text-inverse"
110
- {...secondaryCta}
111
- />
112
- )}
113
- </div>
114
- ) : null}
115
-
116
- {/* desktop bottom link */}
117
- {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
118
- <div className="hidden lg:block">
119
- <Button
120
- {...bottomLink}
121
- linkClassName="text-footnote text-white"
122
- />
123
- </div>
124
- )}
125
-
126
- {pricingDescriptionDisclaimer ? (
127
- <Text as="p" className="body3">
128
- {pricingDescriptionDisclaimer}
129
- </Text>
130
- ) : null}
131
- </div>
132
- </div>
133
- </div>
134
-
135
- {/* mobile hero image and bottom link */}
136
- <div className="lg:hidden">
137
- <div className={"relative my-8"}>
138
- {badgeImage ? (
139
- <NextImage
140
- src={badgeImage}
141
- alt={"Badge"}
142
- className="absolute left-5 top-5 aspect-square w-26 object-cover object-center"
143
- width={100}
144
- height={100}
145
- loading="eager"
146
- />
147
- ) : null}
148
- {carouselImages && carouselImages[0] ? (
149
- <NextImage
150
- src={carouselImages[0]}
151
- alt={"Hero"}
152
- className="aspect-[1.71:1] sm:aspect-[1.41:1] rounded-[40px] object-cover object-center sm:h-[420px]"
153
- width={350}
154
- height={205}
155
- loading="eager"
156
- />
157
- ) : null}
158
- </div>
159
-
160
- {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
161
- <div>
162
- <Button {...bottomLink} linkClassName="body3 text-white" />
163
- </div>
164
- )}
165
-
166
- {pricingDescriptionDisclaimer ? (
167
- <Text as="p" className="body3">
168
- {pricingDescriptionDisclaimer}
169
- </Text>
170
- ) : null}
171
-
172
- {secondaryCtaPrefix || secondaryCta ? (
173
- <div className="flex">
174
- {secondaryCtaPrefix && (
175
- <Text as="span" className="body2 mr-1">
176
- {secondaryCtaPrefix}
177
- </Text>
178
- )}
179
- {secondaryCta && <Button {...secondaryCta} />}
180
- </div>
181
- ) : null}
182
- </div>
183
-
184
- {/* Right column: bright blue background, diagonal top edge, hero image */}
185
- <div className={cx("relative hidden lg:block")}>
186
- {badgeImage ? (
187
- <NextImage
188
- src={badgeImage}
189
- alt={"Badge"}
190
- className="absolute -left-26 top-18 aspect-square w-52 object-cover object-center"
191
- width={200}
192
- height={200}
193
- loading="eager"
194
- />
195
- ) : null}
196
- {carouselImages && carouselImages[0] ? (
197
- <NextImage
198
- src={carouselImages[0]}
199
- alt={"Hero"}
200
- className="aspect-square rounded-[40px] object-cover object-center"
201
- width={600}
202
- height={600}
203
- loading="eager"
204
- />
205
- ) : null}
206
- </div>
207
- </div>
208
- </div>
209
- );
210
- };
211
-
212
- export default PrimaryHero;
1
+ import React from "react";
2
+ import { PrimaryHeroProps } from "./types";
3
+
4
+ import { Checklist } from "@shared/components/checklist";
5
+ import { NextImage } from "@shared/components/next-image";
6
+ import { Text } from "@shared/components/text";
7
+ import { Button } from "@shared/contentful/blocks/button";
8
+ import { cx } from "@shared/utils";
9
+
10
+ export const PrimaryHero: React.FC<PrimaryHeroProps> = props => {
11
+ const {
12
+ title,
13
+ showAsHeading,
14
+ subTitle,
15
+ primaryCta1,
16
+ carouselImages,
17
+ bottomLink,
18
+ price,
19
+ priceCallout,
20
+ priceSuffix,
21
+ checklist,
22
+ checkPlansJSX,
23
+ badgeImage,
24
+ pricingDescriptionDisclaimer,
25
+ secondaryCta,
26
+ secondaryCtaPrefix,
27
+ } = props;
28
+
29
+ const bottomLinkLabel = bottomLink?.buttonLabel ?? bottomLink?.label;
30
+
31
+ return (
32
+ <div className="component-container p-5 lg:h-[724px] lg:p-0">
33
+ <div
34
+ className={cx(
35
+ "primary-hero-container mx-auto flex flex-col sm:items-center sm:text-center lg:h-full lg:max-w-120 lg:flex-row lg:items-center lg:justify-between lg:gap-4 lg:px-4 lg:text-left"
36
+ )}
37
+ >
38
+ {/* Left column: navy background, headline, body, address, button, link */}
39
+ <div className={cx("relative flex flex-col text-white sm:w-[485px]")}>
40
+ <div className="flex flex-col gap-5 lg:gap-6">
41
+ {title && (
42
+ <Text
43
+ as={showAsHeading ? "h1" : "h2"}
44
+ className="heading2 lg:heading1"
45
+ >
46
+ {title}
47
+ </Text>
48
+ )}
49
+ {subTitle && (
50
+ <Text as="p" className="subheading3 lg:subheading1">
51
+ {subTitle}
52
+ </Text>
53
+ )}
54
+
55
+ {/* price callout */}
56
+ {price ? (
57
+ <div className="flex">
58
+ <div className="mr-2 mt-2">
59
+ {priceCallout
60
+ ? priceCallout.split("|").map((line, index) => (
61
+ <Text key={index} as="p" className="body2">
62
+ {line}
63
+ </Text>
64
+ ))
65
+ : null}
66
+ </div>
67
+ <div className="flex">
68
+ <Text as="p" className="subheading1 mt-2">
69
+ $
70
+ </Text>
71
+ <Text as="p" className="subheading5">
72
+ {price}
73
+ </Text>
74
+ {priceSuffix ? (
75
+ <Text as="p" className="subheading1 mt-2">
76
+ {priceSuffix}
77
+ </Text>
78
+ ) : null}
79
+ </div>
80
+ </div>
81
+ ) : null}
82
+
83
+ {/* checklist */}
84
+ {checklist && (
85
+ <Checklist
86
+ listItemClassName="text-white body2"
87
+ items={checklist.map(item => item.title)}
88
+ />
89
+ )}
90
+
91
+ {/* CTA section */}
92
+ <div className="flex flex-col gap-3">
93
+ {/* desktop CTA */}
94
+ {primaryCta1 && (
95
+ <div className={cx("hidden lg:flex lg:flex-col")}>
96
+ <Button {...primaryCta1} checkPlansJSX={checkPlansJSX} />
97
+ </div>
98
+ )}
99
+
100
+ {secondaryCtaPrefix || secondaryCta ? (
101
+ <div className="flex">
102
+ {secondaryCtaPrefix && (
103
+ <Text as="span" className="body2 mr-1">
104
+ {secondaryCtaPrefix}
105
+ </Text>
106
+ )}
107
+ {secondaryCta && (
108
+ <Button
109
+ linkClassName="body2 text-text-inverse"
110
+ {...secondaryCta}
111
+ />
112
+ )}
113
+ </div>
114
+ ) : null}
115
+
116
+ {/* desktop bottom link */}
117
+ {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
118
+ <div className="hidden lg:block">
119
+ <Button
120
+ {...bottomLink}
121
+ linkClassName="text-footnote text-white"
122
+ />
123
+ </div>
124
+ )}
125
+
126
+ {pricingDescriptionDisclaimer ? (
127
+ <Text as="p" className="body3">
128
+ {pricingDescriptionDisclaimer}
129
+ </Text>
130
+ ) : null}
131
+ </div>
132
+ </div>
133
+ </div>
134
+
135
+ {/* mobile hero image and bottom link */}
136
+ <div className="lg:hidden">
137
+ <div className={"relative my-8"}>
138
+ {badgeImage ? (
139
+ <NextImage
140
+ src={badgeImage}
141
+ alt={"Badge"}
142
+ className="absolute left-5 top-5 aspect-square w-26 object-cover object-center"
143
+ width={100}
144
+ height={100}
145
+ loading="eager"
146
+ />
147
+ ) : null}
148
+ {carouselImages && carouselImages[0] ? (
149
+ <NextImage
150
+ src={carouselImages[0]}
151
+ alt={"Hero"}
152
+ className="aspect-[1.71:1] sm:aspect-[1.41:1] rounded-[40px] object-cover object-center sm:h-[420px]"
153
+ width={350}
154
+ height={205}
155
+ loading="eager"
156
+ />
157
+ ) : null}
158
+ </div>
159
+
160
+ {bottomLink && (bottomLinkLabel || bottomLink?.href) && (
161
+ <div>
162
+ <Button {...bottomLink} linkClassName="body3 text-white" />
163
+ </div>
164
+ )}
165
+
166
+ {pricingDescriptionDisclaimer ? (
167
+ <Text as="p" className="body3">
168
+ {pricingDescriptionDisclaimer}
169
+ </Text>
170
+ ) : null}
171
+
172
+ {secondaryCtaPrefix || secondaryCta ? (
173
+ <div className="flex">
174
+ {secondaryCtaPrefix && (
175
+ <Text as="span" className="body2 mr-1">
176
+ {secondaryCtaPrefix}
177
+ </Text>
178
+ )}
179
+ {secondaryCta && <Button {...secondaryCta} />}
180
+ </div>
181
+ ) : null}
182
+ </div>
183
+
184
+ {/* Right column: bright blue background, diagonal top edge, hero image */}
185
+ <div className={cx("relative hidden lg:block")}>
186
+ {badgeImage ? (
187
+ <NextImage
188
+ src={badgeImage}
189
+ alt={"Badge"}
190
+ className="absolute -left-26 top-18 aspect-square w-52 object-cover object-center"
191
+ width={200}
192
+ height={200}
193
+ loading="eager"
194
+ />
195
+ ) : null}
196
+ {carouselImages && carouselImages[0] ? (
197
+ <NextImage
198
+ src={carouselImages[0]}
199
+ alt={"Hero"}
200
+ className="aspect-square rounded-[40px] object-cover object-center"
201
+ width={600}
202
+ height={600}
203
+ loading="eager"
204
+ />
205
+ ) : null}
206
+ </div>
207
+ </div>
208
+ </div>
209
+ );
210
+ };
211
+
212
+ export default PrimaryHero;
@@ -1,30 +1,30 @@
1
- export type PrimaryHeroProps = {
2
- title: string;
3
- showAsHeading?: boolean;
4
- subTitle?: string;
5
- price?: string;
6
- priceSuffix?: string;
7
- priceCallout?: string;
8
- pricingDescription?: string;
9
- pricingDescriptionDisclaimer?: string;
10
- checklist?: {
11
- title: string;
12
- iconUrl?: string;
13
- anchorId?: string;
14
- }[];
15
- logoLockup?: string;
16
- checkAvailabilityEyebrow?: string;
17
- primaryCtaPrefix1?: string;
18
- primaryCtaPrefix2?: string;
19
- primaryCta1?: any;
20
- primaryCta2?: any;
21
- secondaryCtaPrefix?: string;
22
- secondaryCta?: any;
23
- bottomLink?: any;
24
- carouselImages?: string[];
25
- squareImage?: boolean;
26
- badgeImage?: string;
27
- textColor?: string;
28
- maxWidth?: boolean;
29
- checkPlansJSX?: React.ReactNode;
30
- };
1
+ export type PrimaryHeroProps = {
2
+ title: string;
3
+ showAsHeading?: boolean;
4
+ subTitle?: string;
5
+ price?: string;
6
+ priceSuffix?: string;
7
+ priceCallout?: string;
8
+ pricingDescription?: string;
9
+ pricingDescriptionDisclaimer?: string;
10
+ checklist?: {
11
+ title: string;
12
+ iconUrl?: string;
13
+ anchorId?: string;
14
+ }[];
15
+ logoLockup?: string;
16
+ checkAvailabilityEyebrow?: string;
17
+ primaryCtaPrefix1?: string;
18
+ primaryCtaPrefix2?: string;
19
+ primaryCta1?: any;
20
+ primaryCta2?: any;
21
+ secondaryCtaPrefix?: string;
22
+ secondaryCta?: any;
23
+ bottomLink?: any;
24
+ carouselImages?: string[];
25
+ squareImage?: boolean;
26
+ badgeImage?: string;
27
+ textColor?: string;
28
+ maxWidth?: boolean;
29
+ checkPlansJSX?: React.ReactNode;
30
+ };
@@ -1,26 +1,26 @@
1
- import { ShapeBackgroundWrapper } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof ShapeBackgroundWrapper> = {
7
- title: "Contentful Blocks/ShapeBackgroundWrapper",
8
- component: ShapeBackgroundWrapper,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component:
16
- "Contentful shape background wrapper block. Wraps children with optional SVG shape background.",
17
- },
18
- },
19
- },
20
- args: {
21
- children: "Content",
22
- },
23
- };
24
- export default meta;
25
- type Story = StoryObj<typeof meta>;
26
- export const Default: Story = {};
1
+ import { ShapeBackgroundWrapper } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof ShapeBackgroundWrapper> = {
7
+ title: "Contentful Blocks/ShapeBackgroundWrapper",
8
+ component: ShapeBackgroundWrapper,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component:
16
+ "Contentful shape background wrapper block. Wraps children with optional SVG shape background.",
17
+ },
18
+ },
19
+ },
20
+ args: {
21
+ children: "Content",
22
+ },
23
+ };
24
+ export default meta;
25
+ type Story = StoryObj<typeof meta>;
26
+ export const Default: Story = {};