@windstream/react-shared-components 0.0.67 → 0.0.69

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 (136) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.d.ts +140 -12
  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 +1 -1
  8. package/dist/index.d.ts +1 -1
  9. package/dist/index.js.map +1 -1
  10. package/dist/styles.css +1 -1
  11. package/package.json +175 -175
  12. package/src/components/accordion/Accordion.stories.tsx +230 -230
  13. package/src/components/accordion/types.ts +10 -10
  14. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  15. package/src/components/alert-card/index.tsx +32 -32
  16. package/src/components/alert-card/types.ts +9 -9
  17. package/src/components/brand-button/BrandButton.stories.tsx +219 -219
  18. package/src/components/brand-button/helpers.ts +35 -35
  19. package/src/components/brand-button/index.tsx +93 -93
  20. package/src/components/brand-button/types.ts +25 -25
  21. package/src/components/button/Button.stories.tsx +108 -108
  22. package/src/components/button/index.tsx +27 -27
  23. package/src/components/button/types.ts +14 -14
  24. package/src/components/call-button/CallButton.stories.tsx +324 -324
  25. package/src/components/call-button/index.tsx +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/collapse/Collapse.stories.tsx +255 -255
  32. package/src/components/collapse/index.tsx +46 -46
  33. package/src/components/collapse/types.ts +6 -6
  34. package/src/components/divider/Divider.stories.tsx +205 -205
  35. package/src/components/divider/index.tsx +22 -22
  36. package/src/components/divider/type.ts +3 -3
  37. package/src/components/image/Image.stories.tsx +113 -113
  38. package/src/components/image/index.tsx +25 -25
  39. package/src/components/image/types.ts +40 -40
  40. package/src/components/input/Input.stories.tsx +325 -325
  41. package/src/components/input/index.tsx +177 -177
  42. package/src/components/input/types.ts +37 -37
  43. package/src/components/link/Link.stories.tsx +163 -163
  44. package/src/components/link/types.ts +25 -25
  45. package/src/components/list/List.stories.tsx +272 -272
  46. package/src/components/list/index.tsx +88 -88
  47. package/src/components/list/list-item/index.tsx +38 -38
  48. package/src/components/list/list-item/types.ts +13 -13
  49. package/src/components/list/types.ts +29 -29
  50. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  51. package/src/components/material-icon/constants.ts +96 -96
  52. package/src/components/material-icon/index.tsx +44 -44
  53. package/src/components/material-icon/types.ts +31 -31
  54. package/src/components/modal/Modal.stories.tsx +171 -171
  55. package/src/components/modal/index.tsx +164 -164
  56. package/src/components/modal/types.ts +24 -24
  57. package/src/components/next-image/index.tsx +32 -32
  58. package/src/components/next-image/types.ts +1 -1
  59. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  60. package/src/components/radio-button/index.tsx +75 -75
  61. package/src/components/radio-button/types.ts +21 -21
  62. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  63. package/src/components/see-more/index.tsx +44 -44
  64. package/src/components/see-more/types.ts +4 -4
  65. package/src/components/select/Select.stories.tsx +411 -411
  66. package/src/components/select/index.tsx +150 -150
  67. package/src/components/select/types.ts +35 -35
  68. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  69. package/src/components/select-plan-button/index.tsx +31 -31
  70. package/src/components/select-plan-button/types.ts +5 -5
  71. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  72. package/src/components/skeleton/index.tsx +61 -61
  73. package/src/components/skeleton/types.ts +4 -4
  74. package/src/components/spinner/Spinner.stories.tsx +335 -335
  75. package/src/components/spinner/index.tsx +44 -44
  76. package/src/components/spinner/types.ts +5 -5
  77. package/src/components/text/Text.stories.tsx +321 -321
  78. package/src/components/text/index.tsx +25 -25
  79. package/src/components/text/types.ts +45 -45
  80. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  81. package/src/components/tooltip/index.tsx +74 -74
  82. package/src/components/tooltip/types.ts +7 -7
  83. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  84. package/src/components/view-cart-button/index.tsx +44 -44
  85. package/src/components/view-cart-button/types.ts +5 -5
  86. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  87. package/src/contentful/blocks/button/index.tsx +64 -64
  88. package/src/contentful/blocks/button/types.ts +24 -24
  89. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  90. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  91. package/src/contentful/blocks/cards/index.tsx +13 -13
  92. package/src/contentful/blocks/cards/product-card/index.tsx +199 -198
  93. package/src/contentful/blocks/cards/product-card/types.ts +18 -18
  94. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -86
  95. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -10
  96. package/src/contentful/blocks/cards/types.ts +1 -1
  97. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  98. package/src/contentful/blocks/carousel/helper.tsx +314 -0
  99. package/src/contentful/blocks/carousel/index.tsx +50 -13
  100. package/src/contentful/blocks/carousel/types.ts +126 -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/types.ts +22 -22
  106. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  107. package/src/contentful/blocks/footer/index.tsx +3 -1
  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/desktop-link-groups.tsx/index.tsx +111 -111
  114. package/src/contentful/blocks/navigation/index.tsx +366 -366
  115. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  116. package/src/contentful/blocks/navigation/types.ts +39 -39
  117. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  118. package/src/contentful/blocks/primary-hero/index.tsx +160 -160
  119. package/src/contentful/blocks/primary-hero/types.ts +30 -30
  120. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  121. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  122. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  123. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  124. package/src/contentful/blocks/text/index.tsx +12 -12
  125. package/src/contentful/blocks/text/types.ts +1 -1
  126. package/src/contentful/index.ts +57 -54
  127. package/src/hooks/use-body-scroll-lock.ts +34 -34
  128. package/src/hooks/use-outside-click.ts +17 -17
  129. package/src/index.ts +96 -96
  130. package/src/next/index.ts +5 -5
  131. package/src/setupTests.ts +46 -46
  132. package/src/stories/DocsTemplate.tsx +24 -24
  133. package/src/styles/globals.css +307 -307
  134. package/src/types/global.d.ts +9 -9
  135. package/src/types/micro-components.ts +80 -80
  136. package/src/utils/index.ts +49 -49
@@ -1,54 +1,54 @@
1
- import React from "react";
2
- import { CtaCalloutProps, ThemeKey } from "./types";
3
-
4
- import { Text } from "@shared/components/text";
5
- import { Button } from "@shared/contentful/blocks/button";
6
-
7
- export const CtaCallout: React.FC<CtaCalloutProps> = ({
8
- title,
9
- background = "white",
10
- button,
11
- color,
12
- contentAlignment,
13
- description,
14
- descriptionAlignment,
15
- enableHeading,
16
- subTitle,
17
- maxWidth = true,
18
- }) => {
19
- const bgColorClasses: Record<ThemeKey, string> = {
20
- blue: "bg-[#07B2E2]",
21
- green: "bg-[#26B170]",
22
- yellow: "bg-[#F5FF1E]",
23
- purple: "bg-[#931D69]",
24
- white: "bg-white",
25
- navy: "bg-[#00002D]",
26
- };
27
- return (
28
- <div className={`${bgColorClasses[background]} component-container`}>
29
- <div
30
- className={`${maxWidth ? "mx-auto max-w-120" : ""} color-${color} flex flex-col ${color == "dark" ? "text-text" : "text-white"} px-5 py-16 lg:px-13 lg:py-24`}
31
- >
32
- <Text
33
- as={enableHeading ? "h1" : "h2"}
34
- className={`heading2 lg:heading1 text-${contentAlignment}`}
35
- >
36
- {title}
37
- </Text>
38
- <Text
39
- as="h3"
40
- className={`subheading3 pt-2 lg:subheading1 lg:pt-3 text-${contentAlignment}`}
41
- >
42
- {subTitle}
43
- </Text>
44
- <div className={`pt-2 text-body1 lg:pt-3 text-${descriptionAlignment}`}>
45
- {description}
46
- </div>
47
- <div className="flex justify-center pt-5 lg:pt-14">
48
- <Button {...button} />
49
- </div>
50
- </div>
51
- </div>
52
- );
53
- };
54
- export default CtaCallout;
1
+ import React from "react";
2
+ import { CtaCalloutProps, ThemeKey } from "./types";
3
+
4
+ import { Text } from "@shared/components/text";
5
+ import { Button } from "@shared/contentful/blocks/button";
6
+
7
+ export const CtaCallout: React.FC<CtaCalloutProps> = ({
8
+ title,
9
+ background = "white",
10
+ button,
11
+ color,
12
+ contentAlignment,
13
+ description,
14
+ descriptionAlignment,
15
+ enableHeading,
16
+ subTitle,
17
+ maxWidth = true,
18
+ }) => {
19
+ const bgColorClasses: Record<ThemeKey, string> = {
20
+ blue: "bg-[#07B2E2]",
21
+ green: "bg-[#26B170]",
22
+ yellow: "bg-[#F5FF1E]",
23
+ purple: "bg-[#931D69]",
24
+ white: "bg-white",
25
+ navy: "bg-[#00002D]",
26
+ };
27
+ return (
28
+ <div className={`${bgColorClasses[background]} component-container`}>
29
+ <div
30
+ className={`${maxWidth ? "mx-auto max-w-120" : ""} color-${color} flex flex-col ${color == "dark" ? "text-text" : "text-white"} px-5 py-16 lg:px-13 lg:py-24`}
31
+ >
32
+ <Text
33
+ as={enableHeading ? "h1" : "h2"}
34
+ className={`heading2 lg:heading1 text-${contentAlignment}`}
35
+ >
36
+ {title}
37
+ </Text>
38
+ <Text
39
+ as="h3"
40
+ className={`subheading3 pt-2 lg:subheading1 lg:pt-3 text-${contentAlignment}`}
41
+ >
42
+ {subTitle}
43
+ </Text>
44
+ <div className={`pt-2 text-body1 lg:pt-3 text-${descriptionAlignment}`}>
45
+ {description}
46
+ </div>
47
+ <div className="flex justify-center pt-5 lg:pt-14">
48
+ <Button {...button} />
49
+ </div>
50
+ </div>
51
+ </div>
52
+ );
53
+ };
54
+ export default CtaCallout;
@@ -1,22 +1,22 @@
1
- import React from "react";
2
-
3
- export type CtaCalloutProps = {
4
- title?: string;
5
- subTitle?: string;
6
- enableHeading?: boolean;
7
- color?: "dark" | "light";
8
- background?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
9
- description?: React.ReactNode;
10
- descriptionAlignment?: "center" | "left" | "right";
11
- contentAlignment?: "center" | "left" | "right";
12
- button?: any;
13
- maxWidth?: boolean;
14
- };
15
-
16
- export type ThemeKey =
17
- | "blue"
18
- | "green"
19
- | "yellow"
20
- | "purple"
21
- | "white"
22
- | "navy";
1
+ import React from "react";
2
+
3
+ export type CtaCalloutProps = {
4
+ title?: string;
5
+ subTitle?: string;
6
+ enableHeading?: boolean;
7
+ color?: "dark" | "light";
8
+ background?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
9
+ description?: React.ReactNode;
10
+ descriptionAlignment?: "center" | "left" | "right";
11
+ contentAlignment?: "center" | "left" | "right";
12
+ button?: any;
13
+ maxWidth?: boolean;
14
+ };
15
+
16
+ export type ThemeKey =
17
+ | "blue"
18
+ | "green"
19
+ | "yellow"
20
+ | "purple"
21
+ | "white"
22
+ | "navy";
@@ -1,34 +1,34 @@
1
- import { FloatingBanner } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof FloatingBanner> = {
7
- title: "Contentful Blocks/FloatingBanner",
8
- component: FloatingBanner,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful floating banner block.",
16
- },
17
- },
18
- },
19
- args: {
20
- title: "test",
21
- enableHeading: false,
22
- subtitle: "Test",
23
- icon: "https://images.ctfassets.net/lefc0joykfg0/xt7XD2oCXK79H8pyMyMb8/18aead59bc97d624b5bd91b2f9f04352/banner_call_icon.svg",
24
- description: <p>test</p>,
25
- cta: null,
26
- disclaimer: <p>test</p>,
27
- background: "green",
28
- color: "light",
29
- maxWidth: true,
30
- },
31
- };
32
- export default meta;
33
- type Story = StoryObj<typeof meta>;
34
- export const Default: Story = {};
1
+ import { FloatingBanner } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof FloatingBanner> = {
7
+ title: "Contentful Blocks/FloatingBanner",
8
+ component: FloatingBanner,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful floating banner block.",
16
+ },
17
+ },
18
+ },
19
+ args: {
20
+ title: "test",
21
+ enableHeading: false,
22
+ subtitle: "Test",
23
+ icon: "https://images.ctfassets.net/lefc0joykfg0/xt7XD2oCXK79H8pyMyMb8/18aead59bc97d624b5bd91b2f9f04352/banner_call_icon.svg",
24
+ description: <p>test</p>,
25
+ cta: null,
26
+ disclaimer: <p>test</p>,
27
+ background: "green",
28
+ color: "light",
29
+ maxWidth: true,
30
+ },
31
+ };
32
+ export default meta;
33
+ type Story = StoryObj<typeof meta>;
34
+ export const Default: Story = {};
@@ -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?: "dark" | "light";
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?: "dark" | "light";
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 = {};
@@ -22,7 +22,9 @@ export const Footer: React.FC<FooterProps> = ({
22
22
  return (
23
23
  <div className="component-container bg-bg-inverse text-white">
24
24
  <div className={` ${maxWidth ? "mx-auto max-w-120" : ""} px-5 py-8`}>
25
- <aside aria-label="Promotions and disclaimers">{body}</aside>
25
+ <aside className="break-words" aria-label="Promotions and disclaimers">
26
+ {body}
27
+ </aside>
26
28
  <div
27
29
  className={
28
30
  "my-8 h-[1px] border-t-0 bg-white opacity-100 lg:my-16 dark:opacity-50"
@@ -1,23 +1,23 @@
1
- import { ImagePromoBar } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof ImagePromoBar> = {
7
- title: "Contentful Blocks/ImagePromoBar",
8
- component: ImagePromoBar,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful image promo bar block.",
16
- },
17
- },
18
- },
19
- args: {},
20
- };
21
- export default meta;
22
- type Story = StoryObj<typeof meta>;
23
- export const Default: Story = {};
1
+ import { ImagePromoBar } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof ImagePromoBar> = {
7
+ title: "Contentful Blocks/ImagePromoBar",
8
+ component: ImagePromoBar,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful image promo bar block.",
16
+ },
17
+ },
18
+ },
19
+ args: {},
20
+ };
21
+ export default meta;
22
+ type Story = StoryObj<typeof meta>;
23
+ export const Default: Story = {};
@@ -1,27 +1,27 @@
1
- import React from "react";
2
-
3
- export type ImagePromoBarProps = {
4
- brow: string;
5
- enableHeading: boolean;
6
- title: string;
7
- subTitle: string;
8
- image: string;
9
- imageWidth: number;
10
- imageHeight: number;
11
- mediaPosition: boolean;
12
- description: React.ReactNode;
13
- openDescriptionLinksOnANewTab: boolean;
14
- checklist: string[];
15
- disclaimer: React.ReactNode;
16
- imageLinks: { url: string; image: string }[];
17
- cta: any;
18
- secondaryCta: any;
19
- ctaDisclaimer: React.ReactNode;
20
- videoLink: {
21
- image?: string;
22
- videoPopup?: boolean;
23
- link?: string;
24
- };
25
- maxWidth?: boolean;
26
- color: "light" | "dark";
27
- };
1
+ import React from "react";
2
+
3
+ export type ImagePromoBarProps = {
4
+ brow: string;
5
+ enableHeading: boolean;
6
+ title: string;
7
+ subTitle: string;
8
+ image: string;
9
+ imageWidth: number;
10
+ imageHeight: number;
11
+ mediaPosition: boolean;
12
+ description: React.ReactNode;
13
+ openDescriptionLinksOnANewTab: boolean;
14
+ checklist: string[];
15
+ disclaimer: React.ReactNode;
16
+ imageLinks: { url: string; image: string }[];
17
+ cta: any;
18
+ secondaryCta: any;
19
+ ctaDisclaimer: React.ReactNode;
20
+ videoLink: {
21
+ image?: string;
22
+ videoPopup?: boolean;
23
+ link?: string;
24
+ };
25
+ maxWidth?: boolean;
26
+ color: "light" | "dark";
27
+ };
@@ -1,23 +1,23 @@
1
- import { Modal } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Modal> = {
7
- title: "Contentful Blocks/Modal",
8
- component: Modal,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component: "Contentful modal 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 { Modal } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Modal> = {
7
+ title: "Contentful Blocks/Modal",
8
+ component: Modal,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component: "Contentful modal block.",
16
+ },
17
+ },
18
+ },
19
+ args: { fields: {} },
20
+ };
21
+ export default meta;
22
+ type Story = StoryObj<typeof meta>;
23
+ export const Default: Story = {};
@@ -1,12 +1,12 @@
1
- import { ModalProps } from "./types";
2
-
3
- import { Text } from "@shared/components/text";
4
-
5
- export const Modal: React.FC<{ fields: ModalProps }> = ({ fields }) => {
6
- return (
7
- <div>
8
- <Text>Modal Block</Text>
9
- </div>
10
- );
11
- };
12
- export default Modal;
1
+ import { ModalProps } from "./types";
2
+
3
+ import { Text } from "@shared/components/text";
4
+
5
+ export const Modal: React.FC<{ fields: ModalProps }> = ({ fields }) => {
6
+ return (
7
+ <div>
8
+ <Text>Modal Block</Text>
9
+ </div>
10
+ );
11
+ };
12
+ export default Modal;
@@ -1 +1 @@
1
- export type ModalProps = {};
1
+ export type ModalProps = {};