@windstream/react-shared-components 0.1.42 → 0.1.44

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 (189) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.d.ts +20 -2
  3. package/dist/contentful/index.esm.js +2 -2
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +2 -2
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +1 -0
  8. package/dist/index.d.ts +1 -0
  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/package.json +185 -185
  15. package/src/components/accordion/Accordion.stories.tsx +230 -230
  16. package/src/components/accordion/index.tsx +70 -70
  17. package/src/components/accordion/types.ts +12 -12
  18. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  19. package/src/components/alert-card/index.tsx +41 -41
  20. package/src/components/alert-card/types.ts +13 -13
  21. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  22. package/src/components/brand-button/helpers.ts +35 -35
  23. package/src/components/brand-button/index.tsx +120 -114
  24. package/src/components/brand-button/types.ts +38 -37
  25. package/src/components/button/Button.stories.tsx +108 -108
  26. package/src/components/button/index.tsx +27 -27
  27. package/src/components/button/types.ts +14 -14
  28. package/src/components/call-button/CallButton.stories.tsx +324 -324
  29. package/src/components/call-button/index.tsx +86 -86
  30. package/src/components/call-button/types.ts +11 -11
  31. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  32. package/src/components/checkbox/index.tsx +197 -197
  33. package/src/components/checkbox/types.ts +27 -27
  34. package/src/components/checklist/Checklist.stories.tsx +150 -150
  35. package/src/components/checklist/index.tsx +61 -61
  36. package/src/components/checklist/types.ts +17 -17
  37. package/src/components/collapse/Collapse.stories.tsx +255 -255
  38. package/src/components/collapse/index.tsx +46 -46
  39. package/src/components/collapse/types.ts +6 -6
  40. package/src/components/divider/Divider.stories.tsx +205 -205
  41. package/src/components/divider/index.tsx +22 -22
  42. package/src/components/divider/type.ts +3 -3
  43. package/src/components/image/Image.stories.tsx +113 -113
  44. package/src/components/image/index.tsx +25 -25
  45. package/src/components/image/types.ts +40 -40
  46. package/src/components/input/Input.stories.tsx +325 -325
  47. package/src/components/input/index.tsx +177 -177
  48. package/src/components/input/types.ts +37 -37
  49. package/src/components/link/Link.stories.tsx +163 -163
  50. package/src/components/link/index.tsx +109 -109
  51. package/src/components/link/types.ts +25 -25
  52. package/src/components/list/List.stories.tsx +272 -272
  53. package/src/components/list/index.tsx +88 -88
  54. package/src/components/list/list-item/index.tsx +38 -38
  55. package/src/components/list/list-item/types.ts +13 -13
  56. package/src/components/list/types.ts +29 -29
  57. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  58. package/src/components/material-icon/constants.ts +98 -98
  59. package/src/components/material-icon/index.tsx +47 -47
  60. package/src/components/material-icon/types.ts +31 -31
  61. package/src/components/modal/Modal.stories.tsx +171 -171
  62. package/src/components/modal/index.tsx +164 -164
  63. package/src/components/modal/types.ts +24 -24
  64. package/src/components/next-image/index.tsx +54 -54
  65. package/src/components/next-image/types.ts +1 -1
  66. package/src/components/pagination/index.tsx +100 -100
  67. package/src/components/pagination/types.ts +6 -6
  68. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  69. package/src/components/radio-button/index.tsx +75 -75
  70. package/src/components/radio-button/types.ts +21 -21
  71. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  72. package/src/components/see-more/index.tsx +44 -44
  73. package/src/components/see-more/types.ts +4 -4
  74. package/src/components/select/Select.stories.tsx +411 -411
  75. package/src/components/select/index.tsx +155 -155
  76. package/src/components/select/types.ts +36 -36
  77. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  78. package/src/components/select-plan-button/index.tsx +63 -63
  79. package/src/components/select-plan-button/types.ts +17 -17
  80. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  81. package/src/components/skeleton/index.tsx +61 -61
  82. package/src/components/skeleton/types.ts +4 -4
  83. package/src/components/spinner/Spinner.stories.tsx +335 -335
  84. package/src/components/spinner/index.tsx +44 -44
  85. package/src/components/spinner/types.ts +5 -5
  86. package/src/components/text/Text.stories.tsx +321 -321
  87. package/src/components/text/index.tsx +25 -25
  88. package/src/components/text/types.ts +45 -45
  89. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  90. package/src/components/tooltip/index.tsx +74 -74
  91. package/src/components/tooltip/types.ts +7 -7
  92. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  93. package/src/components/view-cart-button/index.tsx +42 -42
  94. package/src/components/view-cart-button/types.ts +5 -5
  95. package/src/contentful/blocks/accordion/Accordion.stories.tsx +29 -29
  96. package/src/contentful/blocks/accordion/index.tsx +62 -62
  97. package/src/contentful/blocks/accordion/types.ts +17 -17
  98. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  99. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  100. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +70 -70
  101. package/src/contentful/blocks/anchored-bottom-banner/types.ts +10 -10
  102. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  103. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  104. package/src/contentful/blocks/breadcrumbs/index.tsx +51 -51
  105. package/src/contentful/blocks/breadcrumbs/types.ts +5 -5
  106. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  107. package/src/contentful/blocks/button/index.tsx +130 -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 +251 -251
  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/simple-card/types.ts +28 -28
  120. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  121. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  122. package/src/contentful/blocks/cards/types.ts +1 -1
  123. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  124. package/src/contentful/blocks/carousel/helper.tsx +440 -440
  125. package/src/contentful/blocks/carousel/index.tsx +85 -85
  126. package/src/contentful/blocks/carousel/types.ts +144 -144
  127. package/src/contentful/blocks/comparison-table/index.tsx +27 -27
  128. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  129. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  130. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  131. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  132. package/src/contentful/blocks/cta-callout/index.tsx +69 -69
  133. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  134. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  135. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  136. package/src/contentful/blocks/email-input-block/index.tsx +117 -0
  137. package/src/contentful/blocks/email-input-block/types.ts +16 -0
  138. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  139. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  140. package/src/contentful/blocks/find-kinetic/types.ts +19 -19
  141. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  142. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  143. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  144. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  145. package/src/contentful/blocks/footer/index.tsx +91 -90
  146. package/src/contentful/blocks/footer/types.ts +13 -13
  147. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  148. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  149. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  150. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  151. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  152. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  153. package/src/contentful/blocks/modal/constants.ts +53 -53
  154. package/src/contentful/blocks/modal/index.tsx +107 -107
  155. package/src/contentful/blocks/modal/types.ts +12 -12
  156. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +113 -113
  157. package/src/contentful/blocks/navigation/index.tsx +394 -394
  158. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  159. package/src/contentful/blocks/navigation/types.ts +41 -41
  160. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  161. package/src/contentful/blocks/primary-hero/index.tsx +236 -241
  162. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  163. package/src/contentful/blocks/search-block/index.tsx +90 -90
  164. package/src/contentful/blocks/search-block/types.ts +15 -15
  165. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  166. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  167. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  168. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  169. package/src/contentful/blocks/text/index.tsx +12 -12
  170. package/src/contentful/blocks/text/types.ts +1 -1
  171. package/src/contentful/index.ts +99 -96
  172. package/src/hooks/contentful/use-contentful-rich-text.tsx +310 -310
  173. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  174. package/src/hooks/use-body-scroll-lock.ts +34 -34
  175. package/src/hooks/use-carousel-swipe.ts +264 -264
  176. package/src/hooks/use-outside-click.ts +17 -17
  177. package/src/index.ts +101 -101
  178. package/src/next/index.ts +5 -5
  179. package/src/setupTests.ts +46 -46
  180. package/src/stories/DocsTemplate.tsx +24 -24
  181. package/src/styles/globals.css +343 -343
  182. package/src/types/global.d.ts +9 -9
  183. package/src/types/micro-components.ts +99 -99
  184. package/src/types/utm.ts +49 -49
  185. package/src/utils/contentful/to-document.ts +24 -24
  186. package/src/utils/cookie.ts +84 -84
  187. package/src/utils/cx.ts +49 -49
  188. package/src/utils/index.ts +38 -38
  189. package/src/utils/utm.ts +221 -221
@@ -1,129 +1,130 @@
1
- import React from "react";
2
- import { ButtonProps } from "./types";
3
-
4
- import { BrandButton } from "@shared/components/brand-button";
5
- import { Button as CoreButton } from "@shared/components/button";
6
- import { Link } from "@shared/components/link";
7
- import { MaterialIcon } from "@shared/components/material-icon";
8
- import { buildPreservedQueryHref } from "@shared/utils/utm";
9
-
10
- export const Button: React.FC<ButtonProps> = props => {
11
- const {
12
- showButtonAs = "solid",
13
- buttonVariant = "primary_brand",
14
- buttonLabel,
15
- buttonPrefix,
16
- href,
17
- target = "_blank",
18
- anchorId,
19
- linkClassName,
20
- linkVariant,
21
- fullWidth,
22
- preDefinedFunctionExecution,
23
- renderCheckPlans,
24
- buttonClassName,
25
- clickToOpen,
26
- tabmodalNameToOpen,
27
- onModalButtonClick,
28
- onClick,
29
- iconName,
30
- iconFill = 0,
31
- size,
32
- iconSize = 24,
33
- preserveQueryParameters,
34
- ...rest
35
- } = props;
36
-
37
- if (preDefinedFunctionExecution === "check availability") {
38
- const checkPlansNode = renderCheckPlans?.({
39
- ctaText: buttonLabel,
40
- buttonVariant: buttonVariant,
41
- showButtonAs: showButtonAs,
42
- cta: { ...props },
43
- });
44
- return checkPlansNode;
45
- }
46
-
47
- function handleModalClick() {
48
- if (clickToOpen === "modal") {
49
- onModalButtonClick?.(tabmodalNameToOpen);
50
- }
51
- }
52
-
53
- function linkClick(event: React.MouseEvent<HTMLAnchorElement>) {
54
- handleModalClick();
55
- onClick?.(event);
56
- }
57
-
58
- function buttonClick(event: React.MouseEvent<HTMLButtonElement>) {
59
- handleModalClick();
60
- onClick?.(event);
61
- }
62
-
63
- // Resolve the final href — merge non-UTM query params when preserveQueryParameters is true
64
- const currentSearch =
65
- typeof window !== "undefined" ? window.location.search : "";
66
- const resolvedHref =
67
- href && preserveQueryParameters && currentSearch
68
- ? buildPreservedQueryHref(href, currentSearch)
69
- : href;
70
-
71
- let CTA = (
72
- <CoreButton onClick={buttonClick} className={buttonClassName} {...rest} />
73
- );
74
-
75
- switch (showButtonAs) {
76
- case "solid":
77
- CTA = resolvedHref ? (
78
- <BrandButton
79
- as="a"
80
- href={resolvedHref}
81
- id={anchorId}
82
- variant={buttonVariant}
83
- text={buttonLabel}
84
- label={buttonPrefix}
85
- fullWidth={fullWidth}
86
- size={size}
87
- onClick={linkClick}
88
- />
89
- ) : (
90
- <BrandButton
91
- id={anchorId}
92
- variant={buttonVariant}
93
- text={buttonLabel}
94
- label={buttonPrefix}
95
- fullWidth={fullWidth}
96
- size={size}
97
- onClick={buttonClick}
98
- />
99
- );
100
- break;
101
- case "text":
102
- CTA = (
103
- <Link
104
- href={resolvedHref}
105
- target={target}
106
- variant={linkVariant || "default"}
107
- className={`text-text-brand ${linkClassName || ""}`}
108
- onClick={linkClick}
109
- >
110
- {buttonLabel}{" "}
111
- {iconName && (
112
- <MaterialIcon
113
- name={iconName as any}
114
- size={iconSize}
115
- fill={iconFill}
116
- />
117
- )}
118
- </Link>
119
- );
120
- break;
121
- case "unstyled": // For unstyled, we can use the CoreButton without any additional styling
122
- break;
123
- default: // For default, we can use the CoreButton without any additional styling
124
- break;
125
- }
126
-
127
- return CTA;
128
- };
129
- export default Button;
1
+ import React from "react";
2
+ import { ButtonProps } from "./types";
3
+
4
+ import { BrandButton } from "@shared/components/brand-button";
5
+ import { Button as CoreButton } from "@shared/components/button";
6
+ import { Link } from "@shared/components/link";
7
+ import { MaterialIcon } from "@shared/components/material-icon";
8
+ import { buildPreservedQueryHref } from "@shared/utils/utm";
9
+
10
+ export const Button: React.FC<ButtonProps> = props => {
11
+ const {
12
+ showButtonAs = "solid",
13
+ buttonVariant = "primary_brand",
14
+ buttonLabel,
15
+ buttonPrefix,
16
+ href,
17
+ target = "_blank",
18
+ anchorId,
19
+ linkClassName,
20
+ linkVariant,
21
+ fullWidth,
22
+ preDefinedFunctionExecution,
23
+ renderCheckPlans,
24
+ buttonClassName,
25
+ clickToOpen,
26
+ tabmodalNameToOpen,
27
+ onModalButtonClick,
28
+ onClick,
29
+ iconName,
30
+ iconFill = 0,
31
+ size,
32
+ iconSize = 24,
33
+ preserveQueryParameters,
34
+ ...rest
35
+ } = props;
36
+
37
+ if (preDefinedFunctionExecution === "check availability") {
38
+ const checkPlansNode = renderCheckPlans?.({
39
+ ctaText: buttonLabel,
40
+ buttonVariant: buttonVariant,
41
+ showButtonAs: showButtonAs,
42
+ cta: { ...props },
43
+ });
44
+ return checkPlansNode;
45
+ }
46
+
47
+ function handleModalClick() {
48
+ if (clickToOpen === "modal") {
49
+ onModalButtonClick?.(tabmodalNameToOpen);
50
+ }
51
+ }
52
+
53
+ function linkClick(event: React.MouseEvent<HTMLAnchorElement>) {
54
+ handleModalClick();
55
+ onClick?.(event);
56
+ }
57
+
58
+ function buttonClick(event: React.MouseEvent<HTMLButtonElement>) {
59
+ handleModalClick();
60
+ onClick?.(event);
61
+ }
62
+
63
+ // Resolve the final href — merge non-UTM query params when preserveQueryParameters is true
64
+ const currentSearch =
65
+ typeof window !== "undefined" ? window.location.search : "";
66
+ const resolvedHref =
67
+ href && preserveQueryParameters && currentSearch
68
+ ? buildPreservedQueryHref(href, currentSearch)
69
+ : href;
70
+
71
+ let CTA = (
72
+ <CoreButton onClick={buttonClick} className={buttonClassName} {...rest} />
73
+ );
74
+
75
+ switch (showButtonAs) {
76
+ case "solid":
77
+ CTA = resolvedHref ? (
78
+ <BrandButton
79
+ as="a"
80
+ href={resolvedHref}
81
+ id={anchorId}
82
+ variant={buttonVariant}
83
+ text={buttonLabel}
84
+ label={buttonPrefix}
85
+ fullWidth={fullWidth}
86
+ buttonClassName={buttonClassName}
87
+ size={size}
88
+ onClick={linkClick}
89
+ />
90
+ ) : (
91
+ <BrandButton
92
+ id={anchorId}
93
+ variant={buttonVariant}
94
+ text={buttonLabel}
95
+ label={buttonPrefix}
96
+ fullWidth={fullWidth}
97
+ size={size}
98
+ onClick={buttonClick}
99
+ buttonClassName={buttonClassName}
100
+ />
101
+ );
102
+ break;
103
+ case "text":
104
+ CTA = (
105
+ <Link
106
+ href={resolvedHref}
107
+ target={target}
108
+ variant={linkVariant || "default"}
109
+ className={`text-text-brand ${linkClassName || ""}`}
110
+ onClick={linkClick}
111
+ >
112
+ {buttonLabel}{" "}
113
+ {iconName && (
114
+ <MaterialIcon
115
+ name={iconName as any}
116
+ size={iconSize}
117
+ fill={iconFill}
118
+ />
119
+ )}
120
+ </Link>
121
+ );
122
+ break;
123
+ case "unstyled": // For unstyled, we can use the CoreButton without any additional styling
124
+ break;
125
+ default: // For default, we can use the CoreButton without any additional styling
126
+ break;
127
+ }
128
+ return CTA;
129
+ };
130
+ export default Button;
@@ -1,39 +1,39 @@
1
- import React from "react";
2
-
3
- import { ResponsiveSize } from "@shared/components/brand-button/types";
4
- import { Fill, Size } from "@shared/components/material-icon/types";
5
- import { CheckPlansProps } from "@shared/types/micro-components";
6
-
7
- export type ButtonProps = {
8
- showButtonAs?: "solid" | "text" | "unstyled";
9
- buttonVariant?: "primary_brand" | "secondary" | "primary_inverse";
10
- buttonLabel?: string;
11
- buttonPrefix?: string;
12
- badge?: string;
13
- badgeIcon?: string;
14
- buttonIcon?: string;
15
- buttonIconPosition?: "left" | "right";
16
- href?: string;
17
- target?: "_self" | "_blank";
18
- anchorId?: string;
19
- preserveQueryParameters?: boolean;
20
- clickToOpen?: string;
21
- tabmodalNameToOpen?: string;
22
- preDefinedFunctionExecution?: string;
23
- renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
24
- linkClassName?: string;
25
- buttonClassName?: string;
26
- linkVariant?: "unstyled" | "default";
27
- fullWidth?: boolean;
28
- size?: ResponsiveSize;
29
- onClick?: (
30
- event: React.MouseEvent<HTMLAnchorElement | HTMLButtonElement>
31
- ) => void;
32
- children?: React.ReactNode;
33
- modalTitle?: string;
34
- modalSubtitle?: string;
35
- onModalButtonClick?: (id?: string) => void;
36
- iconName?: string;
37
- iconFill?: Fill;
38
- iconSize?: Size;
39
- };
1
+ import React from "react";
2
+
3
+ import { ResponsiveSize } from "@shared/components/brand-button/types";
4
+ import { Fill, Size } from "@shared/components/material-icon/types";
5
+ import { CheckPlansProps } from "@shared/types/micro-components";
6
+
7
+ export type ButtonProps = {
8
+ showButtonAs?: "solid" | "text" | "unstyled";
9
+ buttonVariant?: "primary_brand" | "secondary" | "primary_inverse";
10
+ buttonLabel?: string;
11
+ buttonPrefix?: string;
12
+ badge?: string;
13
+ badgeIcon?: string;
14
+ buttonIcon?: string;
15
+ buttonIconPosition?: "left" | "right";
16
+ href?: string;
17
+ target?: "_self" | "_blank";
18
+ anchorId?: string;
19
+ preserveQueryParameters?: boolean;
20
+ clickToOpen?: string;
21
+ tabmodalNameToOpen?: string;
22
+ preDefinedFunctionExecution?: string;
23
+ renderCheckPlans?: (overrides?: CheckPlansProps) => React.ReactNode;
24
+ linkClassName?: string;
25
+ buttonClassName?: string;
26
+ linkVariant?: "unstyled" | "default";
27
+ fullWidth?: boolean;
28
+ size?: ResponsiveSize;
29
+ onClick?: (
30
+ event: React.MouseEvent<HTMLAnchorElement | HTMLButtonElement>
31
+ ) => void;
32
+ children?: React.ReactNode;
33
+ modalTitle?: string;
34
+ modalSubtitle?: string;
35
+ onModalButtonClick?: (id?: string) => void;
36
+ iconName?: string;
37
+ iconFill?: Fill;
38
+ iconSize?: Size;
39
+ };
@@ -1,23 +1,23 @@
1
- import { Callout } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Callout> = {
7
- title: "Contentful Blocks/Callout",
8
- component: Callout,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful callout block.",
16
- },
17
- },
18
- },
19
- args: {},
20
- };
21
- export default meta;
22
- type Story = StoryObj<typeof meta>;
23
- export const Default: Story = {};
1
+ import { Callout } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Callout> = {
7
+ title: "Contentful Blocks/Callout",
8
+ component: Callout,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful callout block.",
16
+ },
17
+ },
18
+ },
19
+ args: {},
20
+ };
21
+ export default meta;
22
+ type Story = StoryObj<typeof meta>;
23
+ export const Default: Story = {};
@@ -1,88 +1,88 @@
1
- import React from "react";
2
- import BlogCard from "../cards/blog-card";
3
- import SimpleCard from "../cards/simple-card";
4
- import { CalloutProps } from "./types";
5
-
6
- import { Text } from "@shared/components/text";
7
-
8
- export const Callout: React.FC<CalloutProps> = ({
9
- title,
10
- items,
11
- enableHeading = false,
12
- subtitle,
13
- color = "dark",
14
- maxWidth = true,
15
- maxCardsPerRow,
16
- cardType = "simple",
17
- }) => {
18
- const lgWidth =
19
- {
20
- 1: " lg:w-full",
21
- 2: " lg:w-[calc(50%-0.75rem)]",
22
- 3: " lg:w-[calc(33.3333%-1rem)]",
23
- 4: " lg:w-[calc(25%-1.125rem)]",
24
- }[maxCardsPerRow || 4] || " lg:w-[calc(25%-1.125rem)]";
25
-
26
- const mdWidth = items.length === 1 ? " md:w-full" : " md:w-[calc(50%-1rem)]";
27
-
28
- const renderCard = (item: CalloutProps["items"][number], index: number) => {
29
- if (cardType === "blog") {
30
- const blogItem = item as any;
31
- return (
32
- <BlogCard
33
- title={blogItem.title}
34
- href={blogItem.slug}
35
- description={blogItem.shortDescription}
36
- date={blogItem.blogCreationDate}
37
- category={blogItem.category}
38
- image={blogItem.cover}
39
- asGrid={false}
40
- lgWidth={lgWidth}
41
- mdWidth={mdWidth}
42
- />
43
- );
44
- }
45
- return (
46
- <SimpleCard
47
- key={index}
48
- card={item as any}
49
- lgWidth={lgWidth}
50
- mdWidth={mdWidth}
51
- />
52
- );
53
- };
54
-
55
- return (
56
- <div className="component-container">
57
- <div
58
- className={`mx-5 mb-5 mt-12 ${maxWidth ? "max-w-120 xl:mx-auto" : ""} ${color == "dark" ? "text-text" : "text-white"}`}
59
- >
60
- <div className="callout-container flex flex-col gap-10 md:gap-16">
61
- <div className="title-holder">
62
- {title && (
63
- <Text
64
- as={enableHeading ? "h1" : "h2"}
65
- className="heading2 md:heading1 md:text-center"
66
- >
67
- {title}
68
- </Text>
69
- )}
70
- {subtitle && (
71
- <Text
72
- as={enableHeading ? "h2" : "h3"}
73
- className="subheading3 mt-3 md:subheading1 md:text-center"
74
- >
75
- {subtitle}
76
- </Text>
77
- )}
78
- </div>
79
- <div className="card-holder flex flex-wrap items-stretch justify-center gap-6 self-stretch md:gap-6">
80
- {items.map((item, index: number) => renderCard(item, index))}
81
- </div>
82
- </div>
83
- </div>
84
- </div>
85
- );
86
- };
87
-
88
- export default Callout;
1
+ import React from "react";
2
+ import BlogCard from "../cards/blog-card";
3
+ import SimpleCard from "../cards/simple-card";
4
+ import { CalloutProps } from "./types";
5
+
6
+ import { Text } from "@shared/components/text";
7
+
8
+ export const Callout: React.FC<CalloutProps> = ({
9
+ title,
10
+ items,
11
+ enableHeading = false,
12
+ subtitle,
13
+ color = "dark",
14
+ maxWidth = true,
15
+ maxCardsPerRow,
16
+ cardType = "simple",
17
+ }) => {
18
+ const lgWidth =
19
+ {
20
+ 1: " lg:w-full",
21
+ 2: " lg:w-[calc(50%-0.75rem)]",
22
+ 3: " lg:w-[calc(33.3333%-1rem)]",
23
+ 4: " lg:w-[calc(25%-1.125rem)]",
24
+ }[maxCardsPerRow || 4] || " lg:w-[calc(25%-1.125rem)]";
25
+
26
+ const mdWidth = items.length === 1 ? " md:w-full" : " md:w-[calc(50%-1rem)]";
27
+
28
+ const renderCard = (item: CalloutProps["items"][number], index: number) => {
29
+ if (cardType === "blog") {
30
+ const blogItem = item as any;
31
+ return (
32
+ <BlogCard
33
+ title={blogItem.title}
34
+ href={blogItem.slug}
35
+ description={blogItem.shortDescription}
36
+ date={blogItem.blogCreationDate}
37
+ category={blogItem.category}
38
+ image={blogItem.cover}
39
+ asGrid={false}
40
+ lgWidth={lgWidth}
41
+ mdWidth={mdWidth}
42
+ />
43
+ );
44
+ }
45
+ return (
46
+ <SimpleCard
47
+ key={index}
48
+ card={item as any}
49
+ lgWidth={lgWidth}
50
+ mdWidth={mdWidth}
51
+ />
52
+ );
53
+ };
54
+
55
+ return (
56
+ <div className="component-container">
57
+ <div
58
+ className={`mx-5 mb-5 mt-12 ${maxWidth ? "max-w-120 xl:mx-auto" : ""} ${color == "dark" ? "text-text" : "text-white"}`}
59
+ >
60
+ <div className="callout-container flex flex-col gap-10 md:gap-16">
61
+ <div className="title-holder">
62
+ {title && (
63
+ <Text
64
+ as={enableHeading ? "h1" : "h2"}
65
+ className="heading2 md:heading1 md:text-center"
66
+ >
67
+ {title}
68
+ </Text>
69
+ )}
70
+ {subtitle && (
71
+ <Text
72
+ as={enableHeading ? "h2" : "h3"}
73
+ className="subheading3 mt-3 md:subheading1 md:text-center"
74
+ >
75
+ {subtitle}
76
+ </Text>
77
+ )}
78
+ </div>
79
+ <div className="card-holder flex flex-wrap items-stretch justify-center gap-6 self-stretch md:gap-6">
80
+ {items.map((item, index: number) => renderCard(item, index))}
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ );
86
+ };
87
+
88
+ export default Callout;
@@ -1,15 +1,15 @@
1
- export type CalloutProps = {
2
- title?: string;
3
- enableHeading?: boolean;
4
- subtitle?: string;
5
- applyBoxShadow?: boolean;
6
- cardStackingMobile?: boolean;
7
- bottomText?: string;
8
- color?: "dark" | "light";
9
- cardsWidth?: string;
10
- maxCardsPerRow?: number;
11
- noGutter?: boolean;
12
- items: any[];
13
- maxWidth?: boolean;
14
- cardType?: "simple" | "blog";
15
- };
1
+ export type CalloutProps = {
2
+ title?: string;
3
+ enableHeading?: boolean;
4
+ subtitle?: string;
5
+ applyBoxShadow?: boolean;
6
+ cardStackingMobile?: boolean;
7
+ bottomText?: string;
8
+ color?: "dark" | "light";
9
+ cardsWidth?: string;
10
+ maxCardsPerRow?: number;
11
+ noGutter?: boolean;
12
+ items: any[];
13
+ maxWidth?: boolean;
14
+ cardType?: "simple" | "blog";
15
+ };
@@ -1,23 +1,23 @@
1
- import { Cards } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Cards> = {
7
- title: "Contentful Blocks/Cards",
8
- component: Cards,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful cards block.",
16
- },
17
- },
18
- },
19
- args: { fields: {} },
20
- };
21
- export default meta;
22
- type Story = StoryObj<typeof meta>;
23
- export const Default: Story = {};
1
+ import { Cards } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Cards> = {
7
+ title: "Contentful Blocks/Cards",
8
+ component: Cards,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful cards block.",
16
+ },
17
+ },
18
+ },
19
+ args: { fields: {} },
20
+ };
21
+ export default meta;
22
+ type Story = StoryObj<typeof meta>;
23
+ export const Default: Story = {};