@windstream/react-shared-components 0.1.78 → 0.1.79
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.
- package/README.md +635 -635
- package/dist/contentful/index.d.ts +3 -1
- package/dist/contentful/index.esm.js +3 -3
- package/dist/contentful/index.esm.js.map +1 -1
- package/dist/contentful/index.js +2 -2
- package/dist/contentful/index.js.map +1 -1
- package/dist/core.d.ts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/next/index.esm.js.map +1 -1
- package/dist/next/index.js.map +1 -1
- package/dist/styles.css +1 -1
- package/dist/utils/index.esm.js.map +1 -1
- package/dist/utils/index.js.map +1 -1
- package/package.json +185 -185
- package/src/components/accordion/Accordion.stories.tsx +230 -230
- package/src/components/accordion/index.tsx +70 -70
- package/src/components/accordion/types.ts +12 -12
- package/src/components/alert-card/AlertCard.stories.tsx +171 -171
- package/src/components/alert-card/index.tsx +41 -41
- package/src/components/alert-card/types.ts +13 -13
- package/src/components/brand-button/BrandButton.stories.tsx +223 -223
- package/src/components/brand-button/helpers.ts +35 -35
- package/src/components/brand-button/index.tsx +120 -120
- package/src/components/brand-button/types.ts +38 -38
- package/src/components/button/Button.stories.tsx +108 -108
- package/src/components/button/index.tsx +27 -27
- package/src/components/button/types.ts +14 -14
- package/src/components/call-button/CallButton.stories.tsx +324 -324
- package/src/components/call-button/index.tsx +106 -106
- package/src/components/call-button/types.ts +16 -16
- package/src/components/checkbox/Checkbox.stories.tsx +247 -247
- package/src/components/checkbox/index.tsx +197 -197
- package/src/components/checkbox/types.ts +27 -27
- package/src/components/checklist/Checklist.stories.tsx +150 -150
- package/src/components/checklist/index.tsx +61 -61
- package/src/components/checklist/types.ts +17 -17
- package/src/components/collapse/Collapse.stories.tsx +255 -255
- package/src/components/collapse/index.tsx +46 -46
- package/src/components/collapse/types.ts +6 -6
- package/src/components/divider/Divider.stories.tsx +205 -205
- package/src/components/divider/index.tsx +22 -22
- package/src/components/divider/type.ts +3 -3
- package/src/components/image/Image.stories.tsx +113 -113
- package/src/components/image/index.tsx +25 -25
- package/src/components/image/types.ts +40 -40
- package/src/components/input/Input.stories.tsx +325 -325
- package/src/components/input/index.tsx +177 -177
- package/src/components/input/types.ts +37 -37
- package/src/components/link/Link.stories.tsx +163 -163
- package/src/components/link/index.tsx +116 -116
- package/src/components/link/types.ts +25 -25
- package/src/components/list/List.stories.tsx +272 -272
- package/src/components/list/index.tsx +88 -88
- package/src/components/list/list-item/index.tsx +38 -38
- package/src/components/list/list-item/types.ts +13 -13
- package/src/components/list/types.ts +29 -29
- package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
- package/src/components/material-icon/constants.ts +99 -99
- package/src/components/material-icon/index.tsx +47 -47
- package/src/components/material-icon/types.ts +31 -31
- package/src/components/modal/Modal.stories.tsx +171 -171
- package/src/components/modal/index.tsx +164 -164
- package/src/components/modal/types.ts +24 -24
- package/src/components/next-image/index.tsx +74 -74
- package/src/components/next-image/types.ts +1 -1
- package/src/components/pagination/index.tsx +91 -91
- package/src/components/pagination/types.ts +6 -6
- package/src/components/radio-button/RadioButton.stories.tsx +307 -307
- package/src/components/radio-button/index.tsx +75 -75
- package/src/components/radio-button/types.ts +21 -21
- package/src/components/see-more/SeeMore.stories.tsx +181 -181
- package/src/components/see-more/index.tsx +44 -44
- package/src/components/see-more/types.ts +4 -4
- package/src/components/select/Select.stories.tsx +411 -411
- package/src/components/select/index.tsx +155 -155
- package/src/components/select/types.ts +36 -36
- package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
- package/src/components/select-plan-button/index.tsx +63 -63
- package/src/components/select-plan-button/types.ts +17 -17
- package/src/components/skeleton/Skeleton.stories.tsx +179 -179
- package/src/components/skeleton/index.tsx +61 -61
- package/src/components/skeleton/types.ts +4 -4
- package/src/components/spinner/Spinner.stories.tsx +335 -335
- package/src/components/spinner/index.tsx +44 -44
- package/src/components/spinner/types.ts +5 -5
- package/src/components/text/Text.stories.tsx +321 -321
- package/src/components/text/index.tsx +25 -25
- package/src/components/text/types.ts +45 -45
- package/src/components/tooltip/Tooltip.stories.tsx +219 -219
- package/src/components/tooltip/index.tsx +74 -74
- package/src/components/tooltip/types.ts +7 -7
- package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
- package/src/components/view-cart-button/index.tsx +42 -42
- package/src/components/view-cart-button/types.ts +5 -5
- package/src/contentful/blocks/accordion/Accordion.stories.mocks.tsx +128 -128
- package/src/contentful/blocks/accordion/Accordion.stories.tsx +98 -98
- package/src/contentful/blocks/accordion/index.tsx +112 -112
- package/src/contentful/blocks/accordion/types.ts +34 -34
- package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
- package/src/contentful/blocks/address-input-banner/types.ts +14 -14
- package/src/contentful/blocks/anchored-bottom-banner/index.tsx +181 -181
- package/src/contentful/blocks/anchored-bottom-banner/types.ts +13 -13
- package/src/contentful/blocks/blogs-grid/BlogGrid.stories.mocks.tsx +144 -0
- package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +156 -0
- package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
- package/src/contentful/blocks/blogs-grid/types.ts +26 -26
- package/src/contentful/blocks/blogs-grid-base/index.tsx +119 -119
- package/src/contentful/blocks/blogs-grid-base/types.ts +36 -36
- package/src/contentful/blocks/breadcrumbs/BreadcrumbNavigation.stories.tsx +147 -0
- package/src/contentful/blocks/breadcrumbs/index.tsx +95 -81
- package/src/contentful/blocks/breadcrumbs/types.ts +8 -6
- package/src/contentful/blocks/button/Button.stories.tsx +40 -40
- package/src/contentful/blocks/button/index.tsx +131 -131
- package/src/contentful/blocks/button/types.ts +39 -39
- package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
- package/src/contentful/blocks/callout/index.tsx +265 -265
- package/src/contentful/blocks/callout/types.ts +72 -72
- package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
- package/src/contentful/blocks/cards/blog-card/index.tsx +129 -129
- package/src/contentful/blocks/cards/blog-card/types.ts +34 -34
- package/src/contentful/blocks/cards/floating-image-card/index.tsx +119 -119
- package/src/contentful/blocks/cards/floating-image-card/types.ts +30 -30
- package/src/contentful/blocks/cards/full-image-card/index.tsx +130 -130
- package/src/contentful/blocks/cards/full-image-card/types.ts +29 -29
- package/src/contentful/blocks/cards/index.tsx +13 -13
- package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
- package/src/contentful/blocks/cards/product-card/types.ts +28 -28
- package/src/contentful/blocks/cards/simple-card/index.tsx +325 -325
- package/src/contentful/blocks/cards/simple-card/types.ts +71 -71
- package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
- package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
- package/src/contentful/blocks/cards/types.ts +1 -1
- package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
- package/src/contentful/blocks/carousel/helper.tsx +440 -440
- package/src/contentful/blocks/carousel/index.tsx +85 -85
- package/src/contentful/blocks/carousel/types.ts +144 -144
- package/src/contentful/blocks/cart-retention-banner/index.tsx +105 -105
- package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
- package/src/contentful/blocks/comparison-table/index.tsx +29 -29
- package/src/contentful/blocks/comparison-table/types.ts +6 -6
- package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
- package/src/contentful/blocks/cookiebanner/type.ts +7 -7
- package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
- package/src/contentful/blocks/cta-callout/index.tsx +71 -71
- package/src/contentful/blocks/cta-callout/types.ts +26 -26
- package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
- package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
- package/src/contentful/blocks/email-input-block/index.tsx +116 -116
- package/src/contentful/blocks/email-input-block/types.ts +16 -16
- package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
- package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
- package/src/contentful/blocks/find-kinetic/types.ts +19 -19
- package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
- package/src/contentful/blocks/floating-banner/index.tsx +97 -97
- package/src/contentful/blocks/floating-banner/types.ts +22 -22
- package/src/contentful/blocks/footer/Footer.stories.tsx +317 -317
- package/src/contentful/blocks/footer/index.tsx +91 -91
- package/src/contentful/blocks/footer/types.ts +13 -13
- package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
- package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
- package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
- package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
- package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
- package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
- package/src/contentful/blocks/modal/constants.ts +53 -53
- package/src/contentful/blocks/modal/index.tsx +107 -107
- package/src/contentful/blocks/modal/types.ts +12 -12
- package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +139 -139
- package/src/contentful/blocks/navigation/index.tsx +568 -568
- package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
- package/src/contentful/blocks/navigation/types.ts +71 -71
- package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
- package/src/contentful/blocks/primary-hero/index.tsx +236 -236
- package/src/contentful/blocks/primary-hero/types.ts +37 -37
- package/src/contentful/blocks/search-block/index.tsx +90 -90
- package/src/contentful/blocks/search-block/types.ts +15 -15
- package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
- package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
- package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
- package/src/contentful/blocks/text/Text.stories.tsx +23 -23
- package/src/contentful/blocks/text/index.tsx +12 -12
- package/src/contentful/blocks/text/types.ts +1 -1
- package/src/contentful/index.ts +105 -105
- package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
- package/src/hooks/contentful/use-processed-check-list.ts +63 -63
- package/src/hooks/use-body-scroll-lock.ts +34 -34
- package/src/hooks/use-carousel-swipe.ts +264 -264
- package/src/hooks/use-outside-click.ts +17 -17
- package/src/index.ts +101 -101
- package/src/next/index.ts +5 -5
- package/src/setupTests.ts +46 -46
- package/src/stories/DocsTemplate.tsx +24 -24
- package/src/styles/globals.css +343 -343
- package/src/types/global.d.ts +9 -9
- package/src/types/micro-components.ts +99 -99
- package/src/types/utm.ts +49 -49
- package/src/utils/contentful/to-document.ts +24 -24
- package/src/utils/cookie.ts +84 -84
- package/src/utils/cx.ts +49 -49
- package/src/utils/index.ts +41 -41
- package/src/utils/speed-card-bg.ts +24 -24
- 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,128 +1,128 @@
|
|
|
1
|
-
import { AccordionItem } from "./types";
|
|
2
|
-
|
|
3
|
-
/* ------------
|
|
4
|
-
DEFAULT FAQs (3 – plain text only)
|
|
5
|
-
--------------- */
|
|
6
|
-
|
|
7
|
-
export const FAQ_ITEMS: AccordionItem[] = [
|
|
8
|
-
{
|
|
9
|
-
title: "How much speed do I need in my home?",
|
|
10
|
-
description:
|
|
11
|
-
"The amount of internet speed or bandwidth you need in your home significantly depends on your usage and the number of devices connected to the internet. Connected devices don’t only mean computers and tablets; they include TVs used for streaming, gaming consoles, smart watches, phones, home security cameras and doorbells, home assistants, baby monitors, wireless speakers, and more. Every connected device pulls from your home’s internet bandwidth.",
|
|
12
|
-
},
|
|
13
|
-
{
|
|
14
|
-
title: "Do I qualify for any promotional offers?",
|
|
15
|
-
description:
|
|
16
|
-
"Be sure to register for updates, promotional offers, and special discounts in the form provided. You’ll be able to enjoy an improved internet experience and benefit from newer, faster, and more advanced fiber technology.",
|
|
17
|
-
},
|
|
18
|
-
{
|
|
19
|
-
title: "How fast is Kinetic internet?",
|
|
20
|
-
description:
|
|
21
|
-
"Kinetic offers high internet speeds ranging from 200 Mbps up to Fiber Gig speeds of 1000 Mbps.",
|
|
22
|
-
},
|
|
23
|
-
];
|
|
24
|
-
|
|
25
|
-
/* --------------
|
|
26
|
-
RICH TEXT FAQs (4 – JSX formatted)
|
|
27
|
-
----------------- */
|
|
28
|
-
|
|
29
|
-
export const RICH_FAQ_ITEMS: AccordionItem[] = [
|
|
30
|
-
{
|
|
31
|
-
title: "How do I check my Windstream email?",
|
|
32
|
-
description: (
|
|
33
|
-
<>
|
|
34
|
-
<p>
|
|
35
|
-
<strong>Already have a windstream.net account?</strong>
|
|
36
|
-
</p>
|
|
37
|
-
|
|
38
|
-
<p>You can check your windstream.net emails in the following ways:</p>
|
|
39
|
-
|
|
40
|
-
<ol className="ml-6 list-decimal">
|
|
41
|
-
<li>
|
|
42
|
-
Go to <strong>www.windstream.net</strong> and click{" "}
|
|
43
|
-
<strong>Email</strong> in the top‑right of the menu bar.
|
|
44
|
-
</li>
|
|
45
|
-
<li>Use an email application on a smartphone.</li>
|
|
46
|
-
<li>Use an email client on a computer.</li>
|
|
47
|
-
</ol>
|
|
48
|
-
|
|
49
|
-
<p className="mt-4">
|
|
50
|
-
<strong>OR</strong>
|
|
51
|
-
</p>
|
|
52
|
-
|
|
53
|
-
<p>
|
|
54
|
-
Log in to <strong>Go Kinetic</strong>, navigate to{" "}
|
|
55
|
-
<strong>Other Services</strong>, then select{" "}
|
|
56
|
-
<strong>View and Manage Email</strong>.
|
|
57
|
-
</p>
|
|
58
|
-
|
|
59
|
-
<p className="mt-4">
|
|
60
|
-
<strong>Wanting to set up a new .net email account?</strong>
|
|
61
|
-
</p>
|
|
62
|
-
|
|
63
|
-
<ul className="ml-6 list-disc">
|
|
64
|
-
<li>
|
|
65
|
-
If you do not already have a windstream.net email account, new
|
|
66
|
-
windstream.net email addresses are no longer being created.
|
|
67
|
-
</li>
|
|
68
|
-
<li>
|
|
69
|
-
You can set up a free email account using platforms like{" "}
|
|
70
|
-
<strong>Gmail</strong> or <strong>Yahoo</strong>.
|
|
71
|
-
</li>
|
|
72
|
-
</ul>
|
|
73
|
-
</>
|
|
74
|
-
),
|
|
75
|
-
},
|
|
76
|
-
{
|
|
77
|
-
title: "How much speed do I need in my home?",
|
|
78
|
-
description: (
|
|
79
|
-
<>
|
|
80
|
-
<p>
|
|
81
|
-
For a household with <strong>4+ internet users</strong> who use the
|
|
82
|
-
web for online gaming, music and video streaming, uploading pictures
|
|
83
|
-
and videos, as well as email and browsing, a{" "}
|
|
84
|
-
<strong>1‑Gigabit plan</strong> would be best suited.
|
|
85
|
-
</p>
|
|
86
|
-
|
|
87
|
-
<p className="mt-4">
|
|
88
|
-
This also supports multiple devices such as laptops, smartphones,
|
|
89
|
-
tablets, and TVs connected to the home internet at the same time.
|
|
90
|
-
</p>
|
|
91
|
-
|
|
92
|
-
<p className="mt-4">
|
|
93
|
-
Every connected device in your home pulls from your available internet
|
|
94
|
-
bandwidth.
|
|
95
|
-
</p>
|
|
96
|
-
</>
|
|
97
|
-
),
|
|
98
|
-
},
|
|
99
|
-
{
|
|
100
|
-
title: "Do I qualify for any promotional offers?",
|
|
101
|
-
description: (
|
|
102
|
-
<>
|
|
103
|
-
<p>
|
|
104
|
-
Be sure to register for updates, promotional offers, and special
|
|
105
|
-
discounts using the form below.
|
|
106
|
-
</p>
|
|
107
|
-
|
|
108
|
-
<p className="mt-4">
|
|
109
|
-
Enjoy an improved internet experience and take advantage of newer,
|
|
110
|
-
faster, and more advanced fiber technology.
|
|
111
|
-
</p>
|
|
112
|
-
</>
|
|
113
|
-
),
|
|
114
|
-
},
|
|
115
|
-
{
|
|
116
|
-
title: "Can I change or cancel my pre‑order?",
|
|
117
|
-
description: (
|
|
118
|
-
<>
|
|
119
|
-
<p>
|
|
120
|
-
Yes, of course! You are under no obligation. If a situation arises
|
|
121
|
-
that requires a change, simply give us a call at{" "}
|
|
122
|
-
<strong>855‑939‑2381</strong>.
|
|
123
|
-
</p>
|
|
124
|
-
</>
|
|
125
|
-
),
|
|
126
|
-
},
|
|
127
|
-
];
|
|
128
|
-
``;
|
|
1
|
+
import { AccordionItem } from "./types";
|
|
2
|
+
|
|
3
|
+
/* ------------
|
|
4
|
+
DEFAULT FAQs (3 – plain text only)
|
|
5
|
+
--------------- */
|
|
6
|
+
|
|
7
|
+
export const FAQ_ITEMS: AccordionItem[] = [
|
|
8
|
+
{
|
|
9
|
+
title: "How much speed do I need in my home?",
|
|
10
|
+
description:
|
|
11
|
+
"The amount of internet speed or bandwidth you need in your home significantly depends on your usage and the number of devices connected to the internet. Connected devices don’t only mean computers and tablets; they include TVs used for streaming, gaming consoles, smart watches, phones, home security cameras and doorbells, home assistants, baby monitors, wireless speakers, and more. Every connected device pulls from your home’s internet bandwidth.",
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
title: "Do I qualify for any promotional offers?",
|
|
15
|
+
description:
|
|
16
|
+
"Be sure to register for updates, promotional offers, and special discounts in the form provided. You’ll be able to enjoy an improved internet experience and benefit from newer, faster, and more advanced fiber technology.",
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
title: "How fast is Kinetic internet?",
|
|
20
|
+
description:
|
|
21
|
+
"Kinetic offers high internet speeds ranging from 200 Mbps up to Fiber Gig speeds of 1000 Mbps.",
|
|
22
|
+
},
|
|
23
|
+
];
|
|
24
|
+
|
|
25
|
+
/* --------------
|
|
26
|
+
RICH TEXT FAQs (4 – JSX formatted)
|
|
27
|
+
----------------- */
|
|
28
|
+
|
|
29
|
+
export const RICH_FAQ_ITEMS: AccordionItem[] = [
|
|
30
|
+
{
|
|
31
|
+
title: "How do I check my Windstream email?",
|
|
32
|
+
description: (
|
|
33
|
+
<>
|
|
34
|
+
<p>
|
|
35
|
+
<strong>Already have a windstream.net account?</strong>
|
|
36
|
+
</p>
|
|
37
|
+
|
|
38
|
+
<p>You can check your windstream.net emails in the following ways:</p>
|
|
39
|
+
|
|
40
|
+
<ol className="ml-6 list-decimal">
|
|
41
|
+
<li>
|
|
42
|
+
Go to <strong>www.windstream.net</strong> and click{" "}
|
|
43
|
+
<strong>Email</strong> in the top‑right of the menu bar.
|
|
44
|
+
</li>
|
|
45
|
+
<li>Use an email application on a smartphone.</li>
|
|
46
|
+
<li>Use an email client on a computer.</li>
|
|
47
|
+
</ol>
|
|
48
|
+
|
|
49
|
+
<p className="mt-4">
|
|
50
|
+
<strong>OR</strong>
|
|
51
|
+
</p>
|
|
52
|
+
|
|
53
|
+
<p>
|
|
54
|
+
Log in to <strong>Go Kinetic</strong>, navigate to{" "}
|
|
55
|
+
<strong>Other Services</strong>, then select{" "}
|
|
56
|
+
<strong>View and Manage Email</strong>.
|
|
57
|
+
</p>
|
|
58
|
+
|
|
59
|
+
<p className="mt-4">
|
|
60
|
+
<strong>Wanting to set up a new .net email account?</strong>
|
|
61
|
+
</p>
|
|
62
|
+
|
|
63
|
+
<ul className="ml-6 list-disc">
|
|
64
|
+
<li>
|
|
65
|
+
If you do not already have a windstream.net email account, new
|
|
66
|
+
windstream.net email addresses are no longer being created.
|
|
67
|
+
</li>
|
|
68
|
+
<li>
|
|
69
|
+
You can set up a free email account using platforms like{" "}
|
|
70
|
+
<strong>Gmail</strong> or <strong>Yahoo</strong>.
|
|
71
|
+
</li>
|
|
72
|
+
</ul>
|
|
73
|
+
</>
|
|
74
|
+
),
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
title: "How much speed do I need in my home?",
|
|
78
|
+
description: (
|
|
79
|
+
<>
|
|
80
|
+
<p>
|
|
81
|
+
For a household with <strong>4+ internet users</strong> who use the
|
|
82
|
+
web for online gaming, music and video streaming, uploading pictures
|
|
83
|
+
and videos, as well as email and browsing, a{" "}
|
|
84
|
+
<strong>1‑Gigabit plan</strong> would be best suited.
|
|
85
|
+
</p>
|
|
86
|
+
|
|
87
|
+
<p className="mt-4">
|
|
88
|
+
This also supports multiple devices such as laptops, smartphones,
|
|
89
|
+
tablets, and TVs connected to the home internet at the same time.
|
|
90
|
+
</p>
|
|
91
|
+
|
|
92
|
+
<p className="mt-4">
|
|
93
|
+
Every connected device in your home pulls from your available internet
|
|
94
|
+
bandwidth.
|
|
95
|
+
</p>
|
|
96
|
+
</>
|
|
97
|
+
),
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
title: "Do I qualify for any promotional offers?",
|
|
101
|
+
description: (
|
|
102
|
+
<>
|
|
103
|
+
<p>
|
|
104
|
+
Be sure to register for updates, promotional offers, and special
|
|
105
|
+
discounts using the form below.
|
|
106
|
+
</p>
|
|
107
|
+
|
|
108
|
+
<p className="mt-4">
|
|
109
|
+
Enjoy an improved internet experience and take advantage of newer,
|
|
110
|
+
faster, and more advanced fiber technology.
|
|
111
|
+
</p>
|
|
112
|
+
</>
|
|
113
|
+
),
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
title: "Can I change or cancel my pre‑order?",
|
|
117
|
+
description: (
|
|
118
|
+
<>
|
|
119
|
+
<p>
|
|
120
|
+
Yes, of course! You are under no obligation. If a situation arises
|
|
121
|
+
that requires a change, simply give us a call at{" "}
|
|
122
|
+
<strong>855‑939‑2381</strong>.
|
|
123
|
+
</p>
|
|
124
|
+
</>
|
|
125
|
+
),
|
|
126
|
+
},
|
|
127
|
+
];
|
|
128
|
+
``;
|
|
@@ -1,98 +1,98 @@
|
|
|
1
|
-
import { FAQ_ITEMS, RICH_FAQ_ITEMS } from "./Accordion.stories.mocks";
|
|
2
|
-
import { Accordion } from "./index";
|
|
3
|
-
import type { AccordionProps } from "./types";
|
|
4
|
-
|
|
5
|
-
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
6
|
-
import type { ArgTypes, Meta, StoryObj } from "@storybook/react";
|
|
7
|
-
|
|
8
|
-
/* ------------
|
|
9
|
-
ArgTypes
|
|
10
|
-
--------------- */
|
|
11
|
-
|
|
12
|
-
const argTypes: ArgTypes<AccordionProps> = {
|
|
13
|
-
title: {
|
|
14
|
-
control: { type: "text" as const },
|
|
15
|
-
description: "Title displayed above the accordion",
|
|
16
|
-
},
|
|
17
|
-
items: {
|
|
18
|
-
control: { type: "object" as const },
|
|
19
|
-
description: "Accordion items",
|
|
20
|
-
},
|
|
21
|
-
background: {
|
|
22
|
-
control: { type: "select" as const },
|
|
23
|
-
options: ["blue", "green", "yellow", "purple", "white", "navy", "cream500"],
|
|
24
|
-
description: "Background color of the accordion",
|
|
25
|
-
},
|
|
26
|
-
enableHeading: {
|
|
27
|
-
control: { type: "boolean" as const },
|
|
28
|
-
},
|
|
29
|
-
maxWidth: {
|
|
30
|
-
control: { type: "boolean" as const },
|
|
31
|
-
},
|
|
32
|
-
hashAutoExpand: {
|
|
33
|
-
control: { type: "boolean" as const },
|
|
34
|
-
},
|
|
35
|
-
descriptionMaxWidth: {
|
|
36
|
-
control: { type: "text" as const },
|
|
37
|
-
},
|
|
38
|
-
anchorId: {
|
|
39
|
-
control: { type: "text" as const },
|
|
40
|
-
},
|
|
41
|
-
initialExpandedItems: {
|
|
42
|
-
control: { type: "object" as const },
|
|
43
|
-
},
|
|
44
|
-
itemContainerClassName: {
|
|
45
|
-
table: { disable: true },
|
|
46
|
-
},
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
/* --------
|
|
50
|
-
Meta
|
|
51
|
-
----------- */
|
|
52
|
-
|
|
53
|
-
const meta: Meta<typeof Accordion> = {
|
|
54
|
-
title: "Contentful Blocks/Accordion",
|
|
55
|
-
component: Accordion,
|
|
56
|
-
tags: ["autodocs"],
|
|
57
|
-
argTypes,
|
|
58
|
-
parameters: {
|
|
59
|
-
layout: "centered",
|
|
60
|
-
docs: {
|
|
61
|
-
page: DocsPage,
|
|
62
|
-
description: {
|
|
63
|
-
component:
|
|
64
|
-
"Contentful accordion block used to render collapsible content.",
|
|
65
|
-
},
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
args: {
|
|
69
|
-
title: "FAQs",
|
|
70
|
-
background: "white",
|
|
71
|
-
enableHeading: false,
|
|
72
|
-
maxWidth: true,
|
|
73
|
-
items: [],
|
|
74
|
-
initialExpandedItems: [],
|
|
75
|
-
hashAutoExpand: false,
|
|
76
|
-
descriptionMaxWidth: "max-w-[980px]",
|
|
77
|
-
},
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
export default meta;
|
|
81
|
-
type Story = StoryObj<typeof meta>;
|
|
82
|
-
|
|
83
|
-
/* --------
|
|
84
|
-
Stories
|
|
85
|
-
----------- */
|
|
86
|
-
|
|
87
|
-
export const Default: Story = {
|
|
88
|
-
args: {
|
|
89
|
-
items: FAQ_ITEMS,
|
|
90
|
-
},
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
export const WithRichTextContent = {
|
|
94
|
-
args: {
|
|
95
|
-
title: "FAQs - Rich Content",
|
|
96
|
-
items: RICH_FAQ_ITEMS,
|
|
97
|
-
},
|
|
98
|
-
};
|
|
1
|
+
import { FAQ_ITEMS, RICH_FAQ_ITEMS } from "./Accordion.stories.mocks";
|
|
2
|
+
import { Accordion } from "./index";
|
|
3
|
+
import type { AccordionProps } from "./types";
|
|
4
|
+
|
|
5
|
+
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
6
|
+
import type { ArgTypes, Meta, StoryObj } from "@storybook/react";
|
|
7
|
+
|
|
8
|
+
/* ------------
|
|
9
|
+
ArgTypes
|
|
10
|
+
--------------- */
|
|
11
|
+
|
|
12
|
+
const argTypes: ArgTypes<AccordionProps> = {
|
|
13
|
+
title: {
|
|
14
|
+
control: { type: "text" as const },
|
|
15
|
+
description: "Title displayed above the accordion",
|
|
16
|
+
},
|
|
17
|
+
items: {
|
|
18
|
+
control: { type: "object" as const },
|
|
19
|
+
description: "Accordion items",
|
|
20
|
+
},
|
|
21
|
+
background: {
|
|
22
|
+
control: { type: "select" as const },
|
|
23
|
+
options: ["blue", "green", "yellow", "purple", "white", "navy", "cream500"],
|
|
24
|
+
description: "Background color of the accordion",
|
|
25
|
+
},
|
|
26
|
+
enableHeading: {
|
|
27
|
+
control: { type: "boolean" as const },
|
|
28
|
+
},
|
|
29
|
+
maxWidth: {
|
|
30
|
+
control: { type: "boolean" as const },
|
|
31
|
+
},
|
|
32
|
+
hashAutoExpand: {
|
|
33
|
+
control: { type: "boolean" as const },
|
|
34
|
+
},
|
|
35
|
+
descriptionMaxWidth: {
|
|
36
|
+
control: { type: "text" as const },
|
|
37
|
+
},
|
|
38
|
+
anchorId: {
|
|
39
|
+
control: { type: "text" as const },
|
|
40
|
+
},
|
|
41
|
+
initialExpandedItems: {
|
|
42
|
+
control: { type: "object" as const },
|
|
43
|
+
},
|
|
44
|
+
itemContainerClassName: {
|
|
45
|
+
table: { disable: true },
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
/* --------
|
|
50
|
+
Meta
|
|
51
|
+
----------- */
|
|
52
|
+
|
|
53
|
+
const meta: Meta<typeof Accordion> = {
|
|
54
|
+
title: "Contentful Blocks/Accordion",
|
|
55
|
+
component: Accordion,
|
|
56
|
+
tags: ["autodocs"],
|
|
57
|
+
argTypes,
|
|
58
|
+
parameters: {
|
|
59
|
+
layout: "centered",
|
|
60
|
+
docs: {
|
|
61
|
+
page: DocsPage,
|
|
62
|
+
description: {
|
|
63
|
+
component:
|
|
64
|
+
"Contentful accordion block used to render collapsible content.",
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
},
|
|
68
|
+
args: {
|
|
69
|
+
title: "FAQs",
|
|
70
|
+
background: "white",
|
|
71
|
+
enableHeading: false,
|
|
72
|
+
maxWidth: true,
|
|
73
|
+
items: [],
|
|
74
|
+
initialExpandedItems: [],
|
|
75
|
+
hashAutoExpand: false,
|
|
76
|
+
descriptionMaxWidth: "max-w-[980px]",
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export default meta;
|
|
81
|
+
type Story = StoryObj<typeof meta>;
|
|
82
|
+
|
|
83
|
+
/* --------
|
|
84
|
+
Stories
|
|
85
|
+
----------- */
|
|
86
|
+
|
|
87
|
+
export const Default: Story = {
|
|
88
|
+
args: {
|
|
89
|
+
items: FAQ_ITEMS,
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
export const WithRichTextContent = {
|
|
94
|
+
args: {
|
|
95
|
+
title: "FAQs - Rich Content",
|
|
96
|
+
items: RICH_FAQ_ITEMS,
|
|
97
|
+
},
|
|
98
|
+
};
|