@windstream/react-shared-components 0.1.94 → 0.1.95
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.esm.js +3 -3
- package/dist/contentful/index.esm.js.map +1 -1
- package/dist/contentful/index.js +3 -3
- package/dist/contentful/index.js.map +1 -1
- package/dist/core.d.ts +4 -4
- package/dist/index.esm.js +5 -13
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +5 -13
- package/dist/index.js.map +1 -1
- package/dist/next/index.esm.js +2 -2
- package/dist/next/index.esm.js.map +1 -1
- package/dist/next/index.js +2 -2
- package/dist/next/index.js.map +1 -1
- package/dist/styles.css +1 -1
- package/dist/utils/index.esm.js +1 -1
- package/dist/utils/index.esm.js.map +1 -1
- package/dist/utils/index.js +1 -1
- package/dist/utils/index.js.map +1 -1
- package/package.json +191 -191
- package/src/components/accordion/Accordion.stories.tsx +230 -230
- package/src/components/accordion/index.test.tsx +270 -270
- 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.test.tsx +152 -152
- package/src/components/alert-card/index.tsx +41 -41
- package/src/components/alert-card/types.ts +13 -13
- package/src/components/animation-wrapper/index.test.tsx +424 -424
- package/src/components/animation-wrapper/index.tsx +129 -129
- package/src/components/animation-wrapper/types.ts +11 -11
- 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.test.tsx +292 -292
- 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.test.tsx +91 -91
- 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.test.tsx +260 -260
- 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.test.tsx +252 -252
- 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.test.tsx +231 -231
- package/src/components/checklist/index.tsx +96 -96
- package/src/components/checklist/types.ts +23 -23
- package/src/components/collapse/Collapse.stories.tsx +255 -255
- package/src/components/collapse/index.test.tsx +277 -277
- package/src/components/collapse/index.tsx +47 -47
- package/src/components/collapse/types.ts +6 -6
- package/src/components/divider/Divider.stories.tsx +205 -205
- package/src/components/divider/index.test.tsx +53 -53
- 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.test.tsx +174 -174
- 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.test.tsx +348 -348
- 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.test.tsx +199 -199
- 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.test.tsx +166 -166
- 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.test.tsx +130 -130
- 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.test.tsx +310 -310
- package/src/components/modal/index.tsx +164 -164
- package/src/components/modal/types.ts +24 -24
- package/src/components/next-image/index.test.tsx +406 -406
- package/src/components/next-image/index.tsx +74 -74
- package/src/components/next-image/types.ts +1 -1
- package/src/components/pagination/index.test.tsx +521 -521
- 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.test.tsx +151 -151
- 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.test.tsx +96 -96
- 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.test.tsx +256 -256
- 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.test.tsx +173 -173
- 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.test.tsx +74 -74
- 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.test.tsx +76 -76
- 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.test.tsx +65 -65
- 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.test.tsx +50 -50
- 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.test.tsx +57 -57
- 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.test.tsx +218 -218
- package/src/contentful/blocks/accordion/index.tsx +114 -114
- package/src/contentful/blocks/accordion/types.ts +34 -34
- package/src/contentful/blocks/address-input-banner/index.test.tsx +132 -132
- 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.test.tsx +287 -287
- 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 -144
- package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +157 -157
- package/src/contentful/blocks/blogs-grid/index.test.tsx +355 -355
- 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.test.tsx +274 -274
- 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 -147
- package/src/contentful/blocks/breadcrumbs/index.test.tsx +281 -281
- package/src/contentful/blocks/breadcrumbs/index.tsx +95 -95
- package/src/contentful/blocks/breadcrumbs/types.ts +8 -8
- package/src/contentful/blocks/button/Button.stories.tsx +40 -40
- package/src/contentful/blocks/button/index.test.tsx +339 -339
- 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.test.tsx +539 -539
- package/src/contentful/blocks/callout/index.tsx +277 -277
- package/src/contentful/blocks/callout/types.ts +78 -78
- package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
- package/src/contentful/blocks/cards/blog-card/index.test.tsx +218 -218
- 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.test.tsx +201 -201
- 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.test.tsx +216 -216
- 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.test.tsx +39 -39
- package/src/contentful/blocks/cards/index.tsx +13 -13
- package/src/contentful/blocks/cards/product-card/index.test.tsx +263 -263
- 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.test.tsx +364 -364
- 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.test.tsx +180 -180
- 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.test.tsx +539 -539
- package/src/contentful/blocks/carousel/helper.tsx +494 -494
- package/src/contentful/blocks/carousel/index.test.tsx +308 -308
- package/src/contentful/blocks/carousel/index.tsx +87 -87
- package/src/contentful/blocks/carousel/types.test.ts +16 -16
- package/src/contentful/blocks/carousel/types.ts +145 -145
- package/src/contentful/blocks/cart-retention-banner/index.test.tsx +409 -409
- package/src/contentful/blocks/cart-retention-banner/index.tsx +109 -109
- package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
- package/src/contentful/blocks/comparison-table/index.test.tsx +114 -114
- 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.test.tsx +277 -277
- 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.test.tsx +244 -244
- package/src/contentful/blocks/cta-callout/index.tsx +73 -73
- package/src/contentful/blocks/cta-callout/types.ts +26 -26
- package/src/contentful/blocks/dynamic-tabs/index.test.tsx +240 -240
- 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.test.tsx +213 -213
- package/src/contentful/blocks/email-input-block/index.tsx +121 -121
- 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.test.tsx +269 -269
- package/src/contentful/blocks/find-kinetic/index.tsx +138 -138
- package/src/contentful/blocks/find-kinetic/types.ts +20 -20
- package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
- package/src/contentful/blocks/floating-banner/index.test.tsx +246 -246
- 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.test.tsx +302 -302
- 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.test.tsx +61 -61
- package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
- package/src/contentful/blocks/image-promo-bar/index.test.tsx +467 -467
- package/src/contentful/blocks/image-promo-bar/index.tsx +8 -6
- package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
- package/src/contentful/blocks/image-promo-bar/vimeo-embed.test.tsx +142 -142
- package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
- package/src/contentful/blocks/image-promo-bar/youtube-embed.test.tsx +104 -104
- 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.test.tsx +209 -209
- package/src/contentful/blocks/modal/index.tsx +108 -108
- package/src/contentful/blocks/modal/types.ts +12 -12
- package/src/contentful/blocks/navigation/Navigation.stories.mocks.tsx +78 -78
- package/src/contentful/blocks/navigation/Navigation.stories.tsx +138 -138
- package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.test.tsx +208 -208
- package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +141 -141
- package/src/contentful/blocks/navigation/index.test.tsx +924 -924
- package/src/contentful/blocks/navigation/index.tsx +569 -569
- package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.test.tsx +131 -131
- 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.test.tsx +286 -286
- package/src/contentful/blocks/primary-hero/index.tsx +239 -239
- package/src/contentful/blocks/primary-hero/types.ts +37 -37
- package/src/contentful/blocks/search-block/index.test.tsx +268 -268
- 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.test.tsx +284 -284
- 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.test.tsx +36 -36
- package/src/contentful/blocks/text/index.tsx +12 -12
- package/src/contentful/blocks/text/types.ts +1 -1
- package/src/contentful/index.test.ts +45 -45
- package/src/contentful/index.ts +105 -105
- package/src/global-mocks/contentful/to-document.ts +25 -25
- package/src/global-mocks/cookie.ts +48 -48
- package/src/global-mocks/cx.ts +37 -37
- package/src/global-mocks/index.ts +89 -89
- package/src/global-mocks/speed-card-bg.ts +27 -27
- package/src/global-mocks/utm.ts +49 -49
- package/src/hooks/contentful/use-contentful-rich-text.test.tsx +1758 -1758
- package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
- package/src/hooks/contentful/use-processed-check-list.test.tsx +277 -277
- package/src/hooks/contentful/use-processed-check-list.ts +63 -63
- package/src/hooks/use-body-scroll-lock.test.ts +134 -134
- package/src/hooks/use-body-scroll-lock.ts +34 -34
- package/src/hooks/use-carousel-swipe.test.ts +393 -393
- package/src/hooks/use-carousel-swipe.ts +264 -264
- package/src/hooks/use-outside-click.test.ts +142 -142
- package/src/hooks/use-outside-click.ts +17 -17
- package/src/index.ts +107 -107
- package/src/next/index.test.ts +7 -7
- package/src/next/index.ts +5 -5
- package/src/setupTests.ts +52 -52
- 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.test.ts +85 -85
- package/src/utils/contentful/to-document.ts +24 -24
- package/src/utils/cookie.test.ts +180 -180
- package/src/utils/cookie.ts +84 -84
- package/src/utils/cx.test.ts +90 -90
- package/src/utils/cx.ts +49 -49
- package/src/utils/index.test.ts +115 -115
- package/src/utils/index.ts +41 -41
- package/src/utils/speed-card-bg.test.ts +46 -46
- package/src/utils/speed-card-bg.ts +24 -24
- package/src/utils/utm.test.ts +359 -359
- package/src/utils/utm.ts +221 -221
|
@@ -1,131 +1,131 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import { MobileLinkGroups } from "./index";
|
|
3
|
-
|
|
4
|
-
import { fireEvent, render, screen } from "@testing-library/react";
|
|
5
|
-
|
|
6
|
-
jest.mock("@shared/components/material-icon", () => ({
|
|
7
|
-
MaterialIcon: ({ name, className }: any) => (
|
|
8
|
-
<span data-testid={`icon-${name}`} className={className}>
|
|
9
|
-
{name}
|
|
10
|
-
</span>
|
|
11
|
-
),
|
|
12
|
-
}));
|
|
13
|
-
|
|
14
|
-
jest.mock("@shared/contentful/blocks/button", () => ({
|
|
15
|
-
Button: ({
|
|
16
|
-
children,
|
|
17
|
-
buttonClassName,
|
|
18
|
-
onClick,
|
|
19
|
-
linkClassName,
|
|
20
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
21
|
-
linkVariant,
|
|
22
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
23
|
-
showButtonAs,
|
|
24
|
-
...rest
|
|
25
|
-
}: any) => (
|
|
26
|
-
<button
|
|
27
|
-
data-testid="button"
|
|
28
|
-
className={buttonClassName || linkClassName}
|
|
29
|
-
onClick={onClick}
|
|
30
|
-
aria-expanded={rest["aria-expanded"]}
|
|
31
|
-
>
|
|
32
|
-
{children || rest.buttonLabel}
|
|
33
|
-
</button>
|
|
34
|
-
),
|
|
35
|
-
}));
|
|
36
|
-
|
|
37
|
-
describe("MobileLinkGroups", () => {
|
|
38
|
-
it("renders nothing when link is undefined", () => {
|
|
39
|
-
const { container } = render(<MobileLinkGroups link={undefined} />);
|
|
40
|
-
expect(container.innerHTML).toBe("");
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
it("renders single Button when link has href (isButton)", () => {
|
|
44
|
-
const link = { href: "/shop", buttonLabel: "Shop", anchorId: "shop1" };
|
|
45
|
-
render(<MobileLinkGroups link={link as any} />);
|
|
46
|
-
expect(screen.getByTestId("button")).toHaveTextContent("Shop");
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
describe("Group rendering", () => {
|
|
50
|
-
const groupLink = {
|
|
51
|
-
anchorId: "grp-1",
|
|
52
|
-
title: "Services",
|
|
53
|
-
items: {
|
|
54
|
-
items: [
|
|
55
|
-
{ buttonLabel: "Internet", href: "/internet", anchorId: "s1" },
|
|
56
|
-
{ buttonLabel: "TV", href: "/tv", anchorId: "s2" },
|
|
57
|
-
],
|
|
58
|
-
},
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
it("renders group title button", () => {
|
|
62
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
63
|
-
expect(screen.getByText("Services")).toBeInTheDocument();
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
it("renders down arrow icon when closed", () => {
|
|
67
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
68
|
-
expect(
|
|
69
|
-
screen.getByTestId("icon-keyboard_arrow_down")
|
|
70
|
-
).toBeInTheDocument();
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
it("toggles open state and shows up arrow when open", () => {
|
|
74
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
75
|
-
const toggleBtn = screen.getAllByTestId("button")[0];
|
|
76
|
-
fireEvent.click(toggleBtn);
|
|
77
|
-
expect(screen.getByTestId("icon-keyboard_arrow_up")).toBeInTheDocument();
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it("renders submenu items when open", () => {
|
|
81
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
82
|
-
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
83
|
-
expect(screen.getByText("Internet")).toBeInTheDocument();
|
|
84
|
-
expect(screen.getByText("TV")).toBeInTheDocument();
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it("renders submenu as list items", () => {
|
|
88
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
89
|
-
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
90
|
-
const listItems = screen.getAllByRole("listitem");
|
|
91
|
-
expect(listItems).toHaveLength(2);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it("closes on second toggle click", () => {
|
|
95
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
96
|
-
const toggleBtn = screen.getAllByTestId("button")[0];
|
|
97
|
-
fireEvent.click(toggleBtn);
|
|
98
|
-
fireEvent.click(toggleBtn);
|
|
99
|
-
expect(
|
|
100
|
-
screen.getByTestId("icon-keyboard_arrow_down")
|
|
101
|
-
).toBeInTheDocument();
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it("does not render submenu when closed", () => {
|
|
105
|
-
render(<MobileLinkGroups link={groupLink as any} />);
|
|
106
|
-
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
it("handles null items", () => {
|
|
110
|
-
const nullItems = { ...groupLink, items: null };
|
|
111
|
-
render(<MobileLinkGroups link={nullItems as any} />);
|
|
112
|
-
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
113
|
-
// No list rendered since subMenu is empty
|
|
114
|
-
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
it("handles empty items array", () => {
|
|
118
|
-
const emptyItems = { ...groupLink, items: { items: [] } };
|
|
119
|
-
render(<MobileLinkGroups link={emptyItems as any} />);
|
|
120
|
-
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
121
|
-
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it("renders null title when title is missing", () => {
|
|
125
|
-
const noTitle = { ...groupLink, title: null };
|
|
126
|
-
render(<MobileLinkGroups link={noTitle as any} />);
|
|
127
|
-
// Should render without error, button exists
|
|
128
|
-
expect(screen.getAllByTestId("button")[0]).toBeInTheDocument();
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
});
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { MobileLinkGroups } from "./index";
|
|
3
|
+
|
|
4
|
+
import { fireEvent, render, screen } from "@testing-library/react";
|
|
5
|
+
|
|
6
|
+
jest.mock("@shared/components/material-icon", () => ({
|
|
7
|
+
MaterialIcon: ({ name, className }: any) => (
|
|
8
|
+
<span data-testid={`icon-${name}`} className={className}>
|
|
9
|
+
{name}
|
|
10
|
+
</span>
|
|
11
|
+
),
|
|
12
|
+
}));
|
|
13
|
+
|
|
14
|
+
jest.mock("@shared/contentful/blocks/button", () => ({
|
|
15
|
+
Button: ({
|
|
16
|
+
children,
|
|
17
|
+
buttonClassName,
|
|
18
|
+
onClick,
|
|
19
|
+
linkClassName,
|
|
20
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
21
|
+
linkVariant,
|
|
22
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
23
|
+
showButtonAs,
|
|
24
|
+
...rest
|
|
25
|
+
}: any) => (
|
|
26
|
+
<button
|
|
27
|
+
data-testid="button"
|
|
28
|
+
className={buttonClassName || linkClassName}
|
|
29
|
+
onClick={onClick}
|
|
30
|
+
aria-expanded={rest["aria-expanded"]}
|
|
31
|
+
>
|
|
32
|
+
{children || rest.buttonLabel}
|
|
33
|
+
</button>
|
|
34
|
+
),
|
|
35
|
+
}));
|
|
36
|
+
|
|
37
|
+
describe("MobileLinkGroups", () => {
|
|
38
|
+
it("renders nothing when link is undefined", () => {
|
|
39
|
+
const { container } = render(<MobileLinkGroups link={undefined} />);
|
|
40
|
+
expect(container.innerHTML).toBe("");
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
it("renders single Button when link has href (isButton)", () => {
|
|
44
|
+
const link = { href: "/shop", buttonLabel: "Shop", anchorId: "shop1" };
|
|
45
|
+
render(<MobileLinkGroups link={link as any} />);
|
|
46
|
+
expect(screen.getByTestId("button")).toHaveTextContent("Shop");
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
describe("Group rendering", () => {
|
|
50
|
+
const groupLink = {
|
|
51
|
+
anchorId: "grp-1",
|
|
52
|
+
title: "Services",
|
|
53
|
+
items: {
|
|
54
|
+
items: [
|
|
55
|
+
{ buttonLabel: "Internet", href: "/internet", anchorId: "s1" },
|
|
56
|
+
{ buttonLabel: "TV", href: "/tv", anchorId: "s2" },
|
|
57
|
+
],
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
it("renders group title button", () => {
|
|
62
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
63
|
+
expect(screen.getByText("Services")).toBeInTheDocument();
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it("renders down arrow icon when closed", () => {
|
|
67
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
68
|
+
expect(
|
|
69
|
+
screen.getByTestId("icon-keyboard_arrow_down")
|
|
70
|
+
).toBeInTheDocument();
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it("toggles open state and shows up arrow when open", () => {
|
|
74
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
75
|
+
const toggleBtn = screen.getAllByTestId("button")[0];
|
|
76
|
+
fireEvent.click(toggleBtn);
|
|
77
|
+
expect(screen.getByTestId("icon-keyboard_arrow_up")).toBeInTheDocument();
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it("renders submenu items when open", () => {
|
|
81
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
82
|
+
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
83
|
+
expect(screen.getByText("Internet")).toBeInTheDocument();
|
|
84
|
+
expect(screen.getByText("TV")).toBeInTheDocument();
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it("renders submenu as list items", () => {
|
|
88
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
89
|
+
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
90
|
+
const listItems = screen.getAllByRole("listitem");
|
|
91
|
+
expect(listItems).toHaveLength(2);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it("closes on second toggle click", () => {
|
|
95
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
96
|
+
const toggleBtn = screen.getAllByTestId("button")[0];
|
|
97
|
+
fireEvent.click(toggleBtn);
|
|
98
|
+
fireEvent.click(toggleBtn);
|
|
99
|
+
expect(
|
|
100
|
+
screen.getByTestId("icon-keyboard_arrow_down")
|
|
101
|
+
).toBeInTheDocument();
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it("does not render submenu when closed", () => {
|
|
105
|
+
render(<MobileLinkGroups link={groupLink as any} />);
|
|
106
|
+
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
it("handles null items", () => {
|
|
110
|
+
const nullItems = { ...groupLink, items: null };
|
|
111
|
+
render(<MobileLinkGroups link={nullItems as any} />);
|
|
112
|
+
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
113
|
+
// No list rendered since subMenu is empty
|
|
114
|
+
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
it("handles empty items array", () => {
|
|
118
|
+
const emptyItems = { ...groupLink, items: { items: [] } };
|
|
119
|
+
render(<MobileLinkGroups link={emptyItems as any} />);
|
|
120
|
+
fireEvent.click(screen.getAllByTestId("button")[0]);
|
|
121
|
+
expect(screen.queryByRole("list")).not.toBeInTheDocument();
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it("renders null title when title is missing", () => {
|
|
125
|
+
const noTitle = { ...groupLink, title: null };
|
|
126
|
+
render(<MobileLinkGroups link={noTitle as any} />);
|
|
127
|
+
// Should render without error, button exists
|
|
128
|
+
expect(screen.getAllByTestId("button")[0]).toBeInTheDocument();
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
});
|
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
|
|
3
|
-
import { MaterialIcon } from "@shared/components/material-icon";
|
|
4
|
-
import { Button } from "@shared/contentful/blocks/button";
|
|
5
|
-
import { ButtonProps as ContentfulButtonProps } from "@shared/contentful/blocks/button/types";
|
|
6
|
-
|
|
7
|
-
type ComponentButtonGroup = {
|
|
8
|
-
anchorId?: string | null;
|
|
9
|
-
title?: string | null;
|
|
10
|
-
items?: { items?: ContentfulButtonProps[] | null } | null;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
type Link = ContentfulButtonProps | ComponentButtonGroup;
|
|
14
|
-
|
|
15
|
-
type LinkGroupsProps = {
|
|
16
|
-
link?: Link;
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
const isButton = (link: Link): link is ContentfulButtonProps => {
|
|
20
|
-
// If your group never has `href`, this is a simple and effective guard
|
|
21
|
-
return typeof (link as ContentfulButtonProps).href === "string";
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
export const MobileLinkGroups: React.FC<LinkGroupsProps> = ({ link }) => {
|
|
25
|
-
const [isOpen, setIsOpen] = React.useState(false);
|
|
26
|
-
if (!link) return null;
|
|
27
|
-
|
|
28
|
-
// Single button
|
|
29
|
-
if (isButton(link)) {
|
|
30
|
-
return (
|
|
31
|
-
<Button
|
|
32
|
-
key={`submenu-link-btn-${link.anchorId}`}
|
|
33
|
-
{...link}
|
|
34
|
-
linkClassName="label3 flex items-center px-4 text-text-link"
|
|
35
|
-
linkVariant="unstyled"
|
|
36
|
-
/>
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
// Group
|
|
41
|
-
const { anchorId, title, items } = link;
|
|
42
|
-
const subMenu = Array.isArray(items?.items) ? items!.items! : [];
|
|
43
|
-
|
|
44
|
-
return (
|
|
45
|
-
<>
|
|
46
|
-
<Button
|
|
47
|
-
onClick={() => setIsOpen(prev => !prev)}
|
|
48
|
-
aria-expanded={isOpen}
|
|
49
|
-
buttonClassName=" label3 flex items-center px-4"
|
|
50
|
-
key={anchorId}
|
|
51
|
-
showButtonAs="unstyled"
|
|
52
|
-
>
|
|
53
|
-
{title ?? null}
|
|
54
|
-
<MaterialIcon
|
|
55
|
-
weight="200"
|
|
56
|
-
size={24}
|
|
57
|
-
className="text-icon-secondary group-hover:opacity-50"
|
|
58
|
-
name={isOpen ? "keyboard_arrow_up" : "keyboard_arrow_down"}
|
|
59
|
-
/>
|
|
60
|
-
</Button>
|
|
61
|
-
{isOpen && subMenu.length > 0 && <RenderSubMenu items={subMenu} />}
|
|
62
|
-
</>
|
|
63
|
-
);
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
const RenderSubMenu: React.FC<{ items: ContentfulButtonProps[] }> = ({
|
|
67
|
-
items,
|
|
68
|
-
}) => (
|
|
69
|
-
<ul key={`submenu-${items.length}`} className="flex flex-col gap-2">
|
|
70
|
-
{items.map((site, index) => {
|
|
71
|
-
return (
|
|
72
|
-
<li key={`submenu-link-${index}`} className="submenu-link">
|
|
73
|
-
<Button
|
|
74
|
-
{...site}
|
|
75
|
-
linkVariant="unstyled"
|
|
76
|
-
linkClassName="body3 pl-8 pr-4 flex items-center w-full h-11 text-text-link"
|
|
77
|
-
/>
|
|
78
|
-
</li>
|
|
79
|
-
);
|
|
80
|
-
})}
|
|
81
|
-
</ul>
|
|
82
|
-
);
|
|
1
|
+
import React from "react";
|
|
2
|
+
|
|
3
|
+
import { MaterialIcon } from "@shared/components/material-icon";
|
|
4
|
+
import { Button } from "@shared/contentful/blocks/button";
|
|
5
|
+
import { ButtonProps as ContentfulButtonProps } from "@shared/contentful/blocks/button/types";
|
|
6
|
+
|
|
7
|
+
type ComponentButtonGroup = {
|
|
8
|
+
anchorId?: string | null;
|
|
9
|
+
title?: string | null;
|
|
10
|
+
items?: { items?: ContentfulButtonProps[] | null } | null;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
type Link = ContentfulButtonProps | ComponentButtonGroup;
|
|
14
|
+
|
|
15
|
+
type LinkGroupsProps = {
|
|
16
|
+
link?: Link;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const isButton = (link: Link): link is ContentfulButtonProps => {
|
|
20
|
+
// If your group never has `href`, this is a simple and effective guard
|
|
21
|
+
return typeof (link as ContentfulButtonProps).href === "string";
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export const MobileLinkGroups: React.FC<LinkGroupsProps> = ({ link }) => {
|
|
25
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
26
|
+
if (!link) return null;
|
|
27
|
+
|
|
28
|
+
// Single button
|
|
29
|
+
if (isButton(link)) {
|
|
30
|
+
return (
|
|
31
|
+
<Button
|
|
32
|
+
key={`submenu-link-btn-${link.anchorId}`}
|
|
33
|
+
{...link}
|
|
34
|
+
linkClassName="label3 flex items-center px-4 text-text-link"
|
|
35
|
+
linkVariant="unstyled"
|
|
36
|
+
/>
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Group
|
|
41
|
+
const { anchorId, title, items } = link;
|
|
42
|
+
const subMenu = Array.isArray(items?.items) ? items!.items! : [];
|
|
43
|
+
|
|
44
|
+
return (
|
|
45
|
+
<>
|
|
46
|
+
<Button
|
|
47
|
+
onClick={() => setIsOpen(prev => !prev)}
|
|
48
|
+
aria-expanded={isOpen}
|
|
49
|
+
buttonClassName=" label3 flex items-center px-4"
|
|
50
|
+
key={anchorId}
|
|
51
|
+
showButtonAs="unstyled"
|
|
52
|
+
>
|
|
53
|
+
{title ?? null}
|
|
54
|
+
<MaterialIcon
|
|
55
|
+
weight="200"
|
|
56
|
+
size={24}
|
|
57
|
+
className="text-icon-secondary group-hover:opacity-50"
|
|
58
|
+
name={isOpen ? "keyboard_arrow_up" : "keyboard_arrow_down"}
|
|
59
|
+
/>
|
|
60
|
+
</Button>
|
|
61
|
+
{isOpen && subMenu.length > 0 && <RenderSubMenu items={subMenu} />}
|
|
62
|
+
</>
|
|
63
|
+
);
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const RenderSubMenu: React.FC<{ items: ContentfulButtonProps[] }> = ({
|
|
67
|
+
items,
|
|
68
|
+
}) => (
|
|
69
|
+
<ul key={`submenu-${items.length}`} className="flex flex-col gap-2">
|
|
70
|
+
{items.map((site, index) => {
|
|
71
|
+
return (
|
|
72
|
+
<li key={`submenu-link-${index}`} className="submenu-link">
|
|
73
|
+
<Button
|
|
74
|
+
{...site}
|
|
75
|
+
linkVariant="unstyled"
|
|
76
|
+
linkClassName="body3 pl-8 pr-4 flex items-center w-full h-11 text-text-link"
|
|
77
|
+
/>
|
|
78
|
+
</li>
|
|
79
|
+
);
|
|
80
|
+
})}
|
|
81
|
+
</ul>
|
|
82
|
+
);
|
|
@@ -1,71 +1,71 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
|
|
3
|
-
import { Asset, Button, ButtonGroup } from "@shared/types/micro-components";
|
|
4
|
-
|
|
5
|
-
type Color = string;
|
|
6
|
-
|
|
7
|
-
export interface Navigation {
|
|
8
|
-
__typename?: "ComponentNavigation";
|
|
9
|
-
primaryNavigationLogo?: Asset;
|
|
10
|
-
anchorId?: string;
|
|
11
|
-
primaryNavigationLinks?: (Button | ButtonGroup)[];
|
|
12
|
-
|
|
13
|
-
supportNavigationLinks?: ButtonGroup[];
|
|
14
|
-
|
|
15
|
-
utilityNavigationLinks?: (Button | ButtonGroup)[];
|
|
16
|
-
|
|
17
|
-
accountNavigationLinks?: ButtonGroup[]; // limit: 1, but treat as array for consistency
|
|
18
|
-
|
|
19
|
-
searchBarIcon?: Asset;
|
|
20
|
-
searchBarPlaceholder?: string;
|
|
21
|
-
|
|
22
|
-
navigationBackgroundColor?: Color;
|
|
23
|
-
utilityNavBackgroundColor?: Color;
|
|
24
|
-
utilityNavLinkColor?: Color;
|
|
25
|
-
/**
|
|
26
|
-
* Tailwind class (or raw class string) applied to the main nav row's
|
|
27
|
-
* text color, e.g. `"text-white"` or `"text-secondary-navy500"`. Used
|
|
28
|
-
* by section / secondary navbars rendered on a dark background where
|
|
29
|
-
* the labels need to be inverted.
|
|
30
|
-
*/
|
|
31
|
-
navigationLinkColor?: string;
|
|
32
|
-
utilityNavActiveIndex?: number;
|
|
33
|
-
|
|
34
|
-
callNowCtaText?: string;
|
|
35
|
-
callNowCtaIcon?: Asset;
|
|
36
|
-
|
|
37
|
-
displaySearchBar?: boolean;
|
|
38
|
-
displayCallNowCta?: boolean;
|
|
39
|
-
displayUtilityNavigation?: boolean;
|
|
40
|
-
showCallButton?: boolean;
|
|
41
|
-
showMobileSliderMenu?: boolean;
|
|
42
|
-
showCallNowCtaInMainNav?: boolean;
|
|
43
|
-
invocaPhoneNumberLink?: string;
|
|
44
|
-
invocaPhoneNumberDisplayText?: string;
|
|
45
|
-
checkPlansJSX?: React.ReactNode;
|
|
46
|
-
onSearch?: (query: string) => void;
|
|
47
|
-
/** When true, renders a cart icon (desktop utility nav and mobile main nav). */
|
|
48
|
-
displayCartIcon?: boolean;
|
|
49
|
-
/** Final URL the cart icon should navigate to (computed by the host app). */
|
|
50
|
-
cartHref?: string;
|
|
51
|
-
/** When true, shows a small accent dot on the cart icon (e.g. retention/cart-recovery). */
|
|
52
|
-
cartHasRetention?: boolean;
|
|
53
|
-
/** Optional aria-label for the cart icon link. Defaults to "Cart". */
|
|
54
|
-
cartIconAriaLabel?: string;
|
|
55
|
-
/** Optional callback fired when the desktop CallButton is clicked. */
|
|
56
|
-
onCallClickDesktop?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
57
|
-
/** Optional callback fired when the mobile CallButton is clicked. */
|
|
58
|
-
onCallClickMobile?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
59
|
-
/** Optional callback fired when the cart icon is clicked. */
|
|
60
|
-
onCartClick?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
61
|
-
/** Optional logo width in px. Defaults to 76.5. */
|
|
62
|
-
primaryNavigationLogoWidth?: number;
|
|
63
|
-
/** Optional logo height in px. Defaults to 24. */
|
|
64
|
-
primaryNavigationLogoHeight?: number;
|
|
65
|
-
/** When true, hides the CallButton from the mobile main nav row
|
|
66
|
-
* (the one next to the cart icon and hamburger). The drawer
|
|
67
|
-
* still renders the CallButton. Defaults to false. */
|
|
68
|
-
hideMobileCallButton?: boolean;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export type NavigationProps = Navigation;
|
|
1
|
+
import React from "react";
|
|
2
|
+
|
|
3
|
+
import { Asset, Button, ButtonGroup } from "@shared/types/micro-components";
|
|
4
|
+
|
|
5
|
+
type Color = string;
|
|
6
|
+
|
|
7
|
+
export interface Navigation {
|
|
8
|
+
__typename?: "ComponentNavigation";
|
|
9
|
+
primaryNavigationLogo?: Asset;
|
|
10
|
+
anchorId?: string;
|
|
11
|
+
primaryNavigationLinks?: (Button | ButtonGroup)[];
|
|
12
|
+
|
|
13
|
+
supportNavigationLinks?: ButtonGroup[];
|
|
14
|
+
|
|
15
|
+
utilityNavigationLinks?: (Button | ButtonGroup)[];
|
|
16
|
+
|
|
17
|
+
accountNavigationLinks?: ButtonGroup[]; // limit: 1, but treat as array for consistency
|
|
18
|
+
|
|
19
|
+
searchBarIcon?: Asset;
|
|
20
|
+
searchBarPlaceholder?: string;
|
|
21
|
+
|
|
22
|
+
navigationBackgroundColor?: Color;
|
|
23
|
+
utilityNavBackgroundColor?: Color;
|
|
24
|
+
utilityNavLinkColor?: Color;
|
|
25
|
+
/**
|
|
26
|
+
* Tailwind class (or raw class string) applied to the main nav row's
|
|
27
|
+
* text color, e.g. `"text-white"` or `"text-secondary-navy500"`. Used
|
|
28
|
+
* by section / secondary navbars rendered on a dark background where
|
|
29
|
+
* the labels need to be inverted.
|
|
30
|
+
*/
|
|
31
|
+
navigationLinkColor?: string;
|
|
32
|
+
utilityNavActiveIndex?: number;
|
|
33
|
+
|
|
34
|
+
callNowCtaText?: string;
|
|
35
|
+
callNowCtaIcon?: Asset;
|
|
36
|
+
|
|
37
|
+
displaySearchBar?: boolean;
|
|
38
|
+
displayCallNowCta?: boolean;
|
|
39
|
+
displayUtilityNavigation?: boolean;
|
|
40
|
+
showCallButton?: boolean;
|
|
41
|
+
showMobileSliderMenu?: boolean;
|
|
42
|
+
showCallNowCtaInMainNav?: boolean;
|
|
43
|
+
invocaPhoneNumberLink?: string;
|
|
44
|
+
invocaPhoneNumberDisplayText?: string;
|
|
45
|
+
checkPlansJSX?: React.ReactNode;
|
|
46
|
+
onSearch?: (query: string) => void;
|
|
47
|
+
/** When true, renders a cart icon (desktop utility nav and mobile main nav). */
|
|
48
|
+
displayCartIcon?: boolean;
|
|
49
|
+
/** Final URL the cart icon should navigate to (computed by the host app). */
|
|
50
|
+
cartHref?: string;
|
|
51
|
+
/** When true, shows a small accent dot on the cart icon (e.g. retention/cart-recovery). */
|
|
52
|
+
cartHasRetention?: boolean;
|
|
53
|
+
/** Optional aria-label for the cart icon link. Defaults to "Cart". */
|
|
54
|
+
cartIconAriaLabel?: string;
|
|
55
|
+
/** Optional callback fired when the desktop CallButton is clicked. */
|
|
56
|
+
onCallClickDesktop?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
57
|
+
/** Optional callback fired when the mobile CallButton is clicked. */
|
|
58
|
+
onCallClickMobile?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
59
|
+
/** Optional callback fired when the cart icon is clicked. */
|
|
60
|
+
onCartClick?: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
|
61
|
+
/** Optional logo width in px. Defaults to 76.5. */
|
|
62
|
+
primaryNavigationLogoWidth?: number;
|
|
63
|
+
/** Optional logo height in px. Defaults to 24. */
|
|
64
|
+
primaryNavigationLogoHeight?: number;
|
|
65
|
+
/** When true, hides the CallButton from the mobile main nav row
|
|
66
|
+
* (the one next to the cart icon and hamburger). The drawer
|
|
67
|
+
* still renders the CallButton. Defaults to false. */
|
|
68
|
+
hideMobileCallButton?: boolean;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export type NavigationProps = Navigation;
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import { PrimaryHero } from "./index";
|
|
2
|
-
|
|
3
|
-
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
4
|
-
import type { Meta, StoryObj } from "@storybook/react";
|
|
5
|
-
|
|
6
|
-
const meta: Meta<typeof PrimaryHero> = {
|
|
7
|
-
title: "Contentful Blocks/PrimaryHero",
|
|
8
|
-
component: PrimaryHero,
|
|
9
|
-
tags: ["autodocs"],
|
|
10
|
-
parameters: {
|
|
11
|
-
layout: "centered",
|
|
12
|
-
docs: {
|
|
13
|
-
page: DocsPage,
|
|
14
|
-
description: {
|
|
15
|
-
component: "Contentful primary hero block.",
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
},
|
|
19
|
-
args: {},
|
|
20
|
-
};
|
|
21
|
-
export default meta;
|
|
22
|
-
type Story = StoryObj<typeof meta>;
|
|
23
|
-
export const Default: Story = {};
|
|
1
|
+
import { PrimaryHero } from "./index";
|
|
2
|
+
|
|
3
|
+
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
4
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
5
|
+
|
|
6
|
+
const meta: Meta<typeof PrimaryHero> = {
|
|
7
|
+
title: "Contentful Blocks/PrimaryHero",
|
|
8
|
+
component: PrimaryHero,
|
|
9
|
+
tags: ["autodocs"],
|
|
10
|
+
parameters: {
|
|
11
|
+
layout: "centered",
|
|
12
|
+
docs: {
|
|
13
|
+
page: DocsPage,
|
|
14
|
+
description: {
|
|
15
|
+
component: "Contentful primary hero block.",
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
args: {},
|
|
20
|
+
};
|
|
21
|
+
export default meta;
|
|
22
|
+
type Story = StoryObj<typeof meta>;
|
|
23
|
+
export const Default: Story = {};
|