@windstream/react-shared-components 0.1.20 → 0.1.21

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 (160) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.esm.js +3 -3
  3. package/dist/contentful/index.esm.js.map +1 -1
  4. package/dist/contentful/index.js +1 -1
  5. package/dist/contentful/index.js.map +1 -1
  6. package/dist/core.d.ts +1 -1
  7. package/dist/index.d.ts +1 -1
  8. package/dist/index.esm.js +6 -6
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js +6 -6
  11. package/dist/index.js.map +1 -1
  12. package/package.json +182 -182
  13. package/src/components/accordion/Accordion.stories.tsx +230 -230
  14. package/src/components/accordion/types.ts +11 -11
  15. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  16. package/src/components/alert-card/index.tsx +41 -41
  17. package/src/components/alert-card/types.ts +13 -13
  18. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  19. package/src/components/brand-button/helpers.ts +35 -35
  20. package/src/components/brand-button/index.tsx +115 -115
  21. package/src/components/brand-button/types.ts +37 -37
  22. package/src/components/button/Button.stories.tsx +108 -108
  23. package/src/components/button/index.tsx +27 -27
  24. package/src/components/button/types.ts +14 -14
  25. package/src/components/call-button/CallButton.stories.tsx +324 -324
  26. package/src/components/call-button/index.tsx +86 -86
  27. package/src/components/call-button/types.ts +11 -11
  28. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  29. package/src/components/checkbox/index.tsx +197 -197
  30. package/src/components/checkbox/types.ts +27 -27
  31. package/src/components/checklist/Checklist.stories.tsx +150 -150
  32. package/src/components/checklist/index.tsx +59 -59
  33. package/src/components/checklist/types.ts +16 -16
  34. package/src/components/collapse/Collapse.stories.tsx +255 -255
  35. package/src/components/collapse/index.tsx +46 -46
  36. package/src/components/collapse/types.ts +6 -6
  37. package/src/components/divider/Divider.stories.tsx +205 -205
  38. package/src/components/divider/index.tsx +22 -22
  39. package/src/components/divider/type.ts +3 -3
  40. package/src/components/image/Image.stories.tsx +113 -113
  41. package/src/components/image/index.tsx +25 -25
  42. package/src/components/image/types.ts +40 -40
  43. package/src/components/input/Input.stories.tsx +325 -325
  44. package/src/components/input/index.tsx +177 -177
  45. package/src/components/input/types.ts +37 -37
  46. package/src/components/link/Link.stories.tsx +163 -163
  47. package/src/components/link/index.tsx +14 -2
  48. package/src/components/link/types.ts +25 -25
  49. package/src/components/list/List.stories.tsx +272 -272
  50. package/src/components/list/index.tsx +88 -88
  51. package/src/components/list/list-item/index.tsx +38 -38
  52. package/src/components/list/list-item/types.ts +13 -13
  53. package/src/components/list/types.ts +29 -29
  54. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  55. package/src/components/material-icon/constants.ts +98 -98
  56. package/src/components/material-icon/index.tsx +47 -47
  57. package/src/components/material-icon/types.ts +31 -31
  58. package/src/components/modal/Modal.stories.tsx +171 -171
  59. package/src/components/modal/index.tsx +164 -164
  60. package/src/components/modal/types.ts +24 -24
  61. package/src/components/next-image/index.tsx +54 -54
  62. package/src/components/next-image/types.ts +1 -1
  63. package/src/components/pagination/index.tsx +100 -100
  64. package/src/components/pagination/types.ts +6 -6
  65. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  66. package/src/components/radio-button/index.tsx +75 -75
  67. package/src/components/radio-button/types.ts +21 -21
  68. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  69. package/src/components/see-more/index.tsx +44 -44
  70. package/src/components/see-more/types.ts +4 -4
  71. package/src/components/select/Select.stories.tsx +411 -411
  72. package/src/components/select/index.tsx +155 -155
  73. package/src/components/select/types.ts +36 -36
  74. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  75. package/src/components/select-plan-button/index.tsx +57 -57
  76. package/src/components/select-plan-button/types.ts +14 -14
  77. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  78. package/src/components/skeleton/index.tsx +61 -61
  79. package/src/components/skeleton/types.ts +4 -4
  80. package/src/components/spinner/Spinner.stories.tsx +335 -335
  81. package/src/components/spinner/index.tsx +44 -44
  82. package/src/components/spinner/types.ts +5 -5
  83. package/src/components/text/Text.stories.tsx +321 -321
  84. package/src/components/text/index.tsx +25 -25
  85. package/src/components/text/types.ts +45 -45
  86. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  87. package/src/components/tooltip/index.tsx +74 -74
  88. package/src/components/tooltip/types.ts +7 -7
  89. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  90. package/src/components/view-cart-button/index.tsx +42 -42
  91. package/src/components/view-cart-button/types.ts +5 -5
  92. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  93. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  94. package/src/contentful/blocks/blogs-grid/index.tsx +129 -129
  95. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  96. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  97. package/src/contentful/blocks/button/index.tsx +121 -121
  98. package/src/contentful/blocks/button/types.ts +36 -36
  99. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  100. package/src/contentful/blocks/callout/index.tsx +86 -86
  101. package/src/contentful/blocks/callout/types.ts +15 -15
  102. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  103. package/src/contentful/blocks/cards/blog-card/index.tsx +104 -104
  104. package/src/contentful/blocks/cards/blog-card/types.ts +15 -15
  105. package/src/contentful/blocks/cards/index.tsx +13 -13
  106. package/src/contentful/blocks/cards/product-card/index.tsx +208 -208
  107. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  108. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  109. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  110. package/src/contentful/blocks/cards/types.ts +1 -1
  111. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  112. package/src/contentful/blocks/carousel/helper.tsx +356 -356
  113. package/src/contentful/blocks/carousel/index.tsx +73 -73
  114. package/src/contentful/blocks/carousel/types.ts +143 -143
  115. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  116. package/src/contentful/blocks/cta-callout/index.tsx +60 -60
  117. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  118. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  119. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  120. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  121. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  122. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  123. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  124. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  125. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  126. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  127. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  128. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  129. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  130. package/src/contentful/blocks/modal/constants.ts +53 -53
  131. package/src/contentful/blocks/modal/index.tsx +91 -91
  132. package/src/contentful/blocks/modal/types.ts +12 -12
  133. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +113 -113
  134. package/src/contentful/blocks/navigation/index.tsx +394 -394
  135. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  136. package/src/contentful/blocks/navigation/types.ts +41 -41
  137. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  138. package/src/contentful/blocks/primary-hero/index.tsx +234 -234
  139. package/src/contentful/blocks/primary-hero/types.ts +35 -35
  140. package/src/contentful/blocks/search-block/index.tsx +90 -90
  141. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  142. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  143. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  144. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  145. package/src/contentful/blocks/text/index.tsx +12 -12
  146. package/src/contentful/blocks/text/types.ts +1 -1
  147. package/src/contentful/index.ts +75 -75
  148. package/src/hooks/use-body-scroll-lock.ts +34 -34
  149. package/src/hooks/use-outside-click.ts +17 -17
  150. package/src/index.ts +96 -96
  151. package/src/next/index.ts +5 -5
  152. package/src/setupTests.ts +46 -46
  153. package/src/stories/DocsTemplate.tsx +24 -24
  154. package/src/styles/globals.css +343 -343
  155. package/src/types/global.d.ts +9 -9
  156. package/src/types/micro-components.ts +99 -99
  157. package/src/types/utm.ts +49 -49
  158. package/src/utils/cookie.ts +58 -58
  159. package/src/utils/index.ts +65 -65
  160. package/src/utils/utm.ts +221 -221
@@ -1,91 +1,91 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import {
5
- backdropAnimationVariants,
6
- contentAnimationVariants,
7
- sizeToPixel,
8
- } from "./constants";
9
- import { ModalProps } from "./types";
10
- import { motion } from "framer-motion";
11
-
12
- import * as Dialog from "@radix-ui/react-dialog";
13
- import { MaterialIcon } from "@shared/components/material-icon";
14
- import { Text } from "@shared/components/text";
15
- import { Button } from "@shared/contentful/blocks/button";
16
- import { cx } from "@shared/utils";
17
-
18
- export const Modal: React.FC<ModalProps> = props => {
19
- const {
20
- isOpen,
21
- onRequestClose,
22
- size,
23
- title,
24
- content,
25
- description,
26
- children,
27
- bodyClassName,
28
- } = props;
29
-
30
- return (
31
- <Dialog.Root
32
- open={isOpen}
33
- onOpenChange={() => isOpen && onRequestClose?.()}
34
- >
35
- <Dialog.Portal>
36
- <motion.div
37
- initial="closed"
38
- animate={isOpen ? "open" : "closed"}
39
- variants={backdropAnimationVariants}
40
- transition={{ type: "tween", duration: 0.2, ease: "easeInOut" }}
41
- className="fixed inset-0 z-[1000] bg-scrim-bg-modal"
42
- >
43
- <Dialog.Overlay />
44
- </motion.div>
45
- <motion.div
46
- initial="closed"
47
- animate={isOpen ? "open" : "closed"}
48
- variants={contentAnimationVariants}
49
- transition={{ type: "tween", duration: 0.3, ease: "easeInOut" }}
50
- className="fixed left-1/2 top-1/2 z-[1001] w-auto -translate-x-1/2 -translate-y-1/2 focus:outline-none"
51
- >
52
- <Dialog.Content
53
- className={cx(
54
- "fixed left-[50%] top-[50%] w-[90vw] translate-x-[-50%] translate-y-[-50%] rounded-[6px] bg-bg p-[25px] shadow-[hsl(206_22%_7%_/_35%)_0px_10px_38px_-10px,_hsl(206_22%_7%_/_20%)_0px_10px_20px_-15px] focus:outline-none",
55
- bodyClassName
56
- )}
57
- style={{ maxWidth: sizeToPixel[size || "lg"] }}
58
- >
59
- <Dialog.Close asChild={true}>
60
- <Button
61
- showButtonAs="unstyled"
62
- buttonClassName="absolute right-0 top-0 mr-2 mt-2 bg-bg"
63
- >
64
- <MaterialIcon name="close" />
65
- </Button>
66
- </Dialog.Close>
67
- <div className="custom-modal-body max-h-[85vh] overflow-visible">
68
- {title ? (
69
- <Text
70
- className={cx(
71
- "mx-auto mb-3 mt-5 text-center",
72
- "heading5 md:max-w-[80%] md:pt-0",
73
- "mb-5 md:mb-[60px]"
74
- )}
75
- as="h2"
76
- >
77
- {title}
78
- </Text>
79
- ) : null}
80
-
81
- {description ? <Text as="div">{description}</Text> : null}
82
-
83
- {content}
84
- {children ? children : null}
85
- </div>
86
- </Dialog.Content>
87
- </motion.div>
88
- </Dialog.Portal>
89
- </Dialog.Root>
90
- );
91
- };
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import {
5
+ backdropAnimationVariants,
6
+ contentAnimationVariants,
7
+ sizeToPixel,
8
+ } from "./constants";
9
+ import { ModalProps } from "./types";
10
+ import { motion } from "framer-motion";
11
+
12
+ import * as Dialog from "@radix-ui/react-dialog";
13
+ import { MaterialIcon } from "@shared/components/material-icon";
14
+ import { Text } from "@shared/components/text";
15
+ import { Button } from "@shared/contentful/blocks/button";
16
+ import { cx } from "@shared/utils";
17
+
18
+ export const Modal: React.FC<ModalProps> = props => {
19
+ const {
20
+ isOpen,
21
+ onRequestClose,
22
+ size,
23
+ title,
24
+ content,
25
+ description,
26
+ children,
27
+ bodyClassName,
28
+ } = props;
29
+
30
+ return (
31
+ <Dialog.Root
32
+ open={isOpen}
33
+ onOpenChange={() => isOpen && onRequestClose?.()}
34
+ >
35
+ <Dialog.Portal>
36
+ <motion.div
37
+ initial="closed"
38
+ animate={isOpen ? "open" : "closed"}
39
+ variants={backdropAnimationVariants}
40
+ transition={{ type: "tween", duration: 0.2, ease: "easeInOut" }}
41
+ className="fixed inset-0 z-[1000] bg-scrim-bg-modal"
42
+ >
43
+ <Dialog.Overlay />
44
+ </motion.div>
45
+ <motion.div
46
+ initial="closed"
47
+ animate={isOpen ? "open" : "closed"}
48
+ variants={contentAnimationVariants}
49
+ transition={{ type: "tween", duration: 0.3, ease: "easeInOut" }}
50
+ className="fixed left-1/2 top-1/2 z-[1001] w-auto -translate-x-1/2 -translate-y-1/2 focus:outline-none"
51
+ >
52
+ <Dialog.Content
53
+ className={cx(
54
+ "fixed left-[50%] top-[50%] w-[90vw] translate-x-[-50%] translate-y-[-50%] rounded-[6px] bg-bg p-[25px] shadow-[hsl(206_22%_7%_/_35%)_0px_10px_38px_-10px,_hsl(206_22%_7%_/_20%)_0px_10px_20px_-15px] focus:outline-none",
55
+ bodyClassName
56
+ )}
57
+ style={{ maxWidth: sizeToPixel[size || "lg"] }}
58
+ >
59
+ <Dialog.Close asChild={true}>
60
+ <Button
61
+ showButtonAs="unstyled"
62
+ buttonClassName="absolute right-0 top-0 mr-2 mt-2 bg-bg"
63
+ >
64
+ <MaterialIcon name="close" />
65
+ </Button>
66
+ </Dialog.Close>
67
+ <div className="custom-modal-body max-h-[85vh] overflow-visible">
68
+ {title ? (
69
+ <Text
70
+ className={cx(
71
+ "mx-auto mb-3 mt-5 text-center",
72
+ "heading5 md:max-w-[80%] md:pt-0",
73
+ "mb-5 md:mb-[60px]"
74
+ )}
75
+ as="h2"
76
+ >
77
+ {title}
78
+ </Text>
79
+ ) : null}
80
+
81
+ {description ? <Text as="div">{description}</Text> : null}
82
+
83
+ {content}
84
+ {children ? children : null}
85
+ </div>
86
+ </Dialog.Content>
87
+ </motion.div>
88
+ </Dialog.Portal>
89
+ </Dialog.Root>
90
+ );
91
+ };
@@ -1,12 +1,12 @@
1
- import React from "react";
2
-
3
- export type ModalProps = {
4
- isOpen: boolean;
5
- onRequestClose?: () => void;
6
- size?: "lg" | "md" | "sm" | "xl" | "xs";
7
- title?: string;
8
- description?: React.ReactNode;
9
- content?: React.ReactNode;
10
- children?: React.ReactNode;
11
- bodyClassName?: string;
12
- };
1
+ import React from "react";
2
+
3
+ export type ModalProps = {
4
+ isOpen: boolean;
5
+ onRequestClose?: () => void;
6
+ size?: "lg" | "md" | "sm" | "xl" | "xs";
7
+ title?: string;
8
+ description?: React.ReactNode;
9
+ content?: React.ReactNode;
10
+ children?: React.ReactNode;
11
+ bodyClassName?: string;
12
+ };
@@ -1,113 +1,113 @@
1
- import React, { CSSProperties } from "react";
2
-
3
- import { MaterialIcon } from "@shared/components/material-icon";
4
- import { Text } from "@shared/components/text";
5
- import { Button } from "@shared/contentful/blocks/button";
6
- import { ButtonProps as ContentfulButtonProps } from "@shared/contentful/blocks/button/types";
7
- import { useOutsideClick } from "@shared/hooks/use-outside-click";
8
- import { cx } from "@shared/utils";
9
-
10
- type ComponentButtonGroup = {
11
- anchorId?: string | null;
12
- title?: string | null;
13
- items?: { items?: ContentfulButtonProps[] | null } | null;
14
- };
15
-
16
- type Link = ContentfulButtonProps | ComponentButtonGroup;
17
-
18
- type LinkGroupsProps = {
19
- link?: Link;
20
- anchorName: string;
21
- };
22
-
23
- const isButton = (link: Link): link is ContentfulButtonProps => {
24
- // If your group never has `href`, this is a simple and effective guard
25
- return typeof (link as ContentfulButtonProps).href === "string";
26
- };
27
-
28
- export const DesktopLinkGroups: React.FC<LinkGroupsProps> = ({
29
- link,
30
- anchorName,
31
- }) => {
32
- const [isOpen, setIsOpen] = React.useState(false);
33
-
34
- const ref = React.useRef<HTMLDivElement>(null);
35
- useOutsideClick(ref, () => setIsOpen(false));
36
-
37
- if (!link) return null;
38
-
39
- // Single button
40
- if (isButton(link)) {
41
- return (
42
- <Button
43
- key={`submenu-link-btn-${link.anchorId}`}
44
- {...link}
45
- linkClassName="body3 flex items-center text-text h-full"
46
- linkVariant="unstyled"
47
- />
48
- );
49
- }
50
-
51
- // Group
52
- const { anchorId, title, items } = link;
53
- const subMenu = Array.isArray(items?.items) ? items!.items! : [];
54
- const fullAnchorName = `--link-anchor-${anchorName}`;
55
-
56
- return (
57
- <div
58
- className="relative h-full"
59
- style={{ anchorName: fullAnchorName } as CSSProperties}
60
- ref={ref}
61
- >
62
- <Button
63
- onClick={() => setIsOpen(prev => !prev)}
64
- aria-expanded={isOpen}
65
- buttonClassName="group body3 flex h-full text-text items-center"
66
- key={anchorId}
67
- showButtonAs="unstyled"
68
- >
69
- <Text as="span" className="group-hover:underline">
70
- {title ?? null}
71
- </Text>
72
- <MaterialIcon
73
- weight="200"
74
- size={24}
75
- className="text-icon-secondary group-hover:opacity-50"
76
- name={isOpen ? "keyboard_arrow_up" : "keyboard_arrow_down"}
77
- />
78
- </Button>
79
-
80
- <div
81
- className={cx(
82
- "shadow-navDrop fixed z-10 min-w-44 rounded-input-poppers border border-border bg-bg",
83
- "transition-[opacity,transform] ease-out",
84
- isOpen && subMenu.length > 0
85
- ? "pointer-events-auto translate-y-0 opacity-100 duration-75"
86
- : "pointer-events-none -translate-y-2 opacity-0 duration-0"
87
- )}
88
- style={
89
- {
90
- positionAnchor: fullAnchorName,
91
- top: "anchor(bottom)",
92
- left: "calc((anchor(left) + anchor(right)) / 2)",
93
- translate: "-50% 0",
94
- } as CSSProperties
95
- }
96
- >
97
- <ul className="flex flex-col gap-2 py-2">
98
- {subMenu.map((site, index) => {
99
- return (
100
- <li key={`submenu-link-${index}`} className="submenu-link">
101
- <Button
102
- {...site}
103
- linkVariant="unstyled"
104
- linkClassName="body3 px-4 hover:bg-bg-surface-hover flex items-center w-full h-11 text-text-link"
105
- />
106
- </li>
107
- );
108
- })}
109
- </ul>
110
- </div>
111
- </div>
112
- );
113
- };
1
+ import React, { CSSProperties } from "react";
2
+
3
+ import { MaterialIcon } from "@shared/components/material-icon";
4
+ import { Text } from "@shared/components/text";
5
+ import { Button } from "@shared/contentful/blocks/button";
6
+ import { ButtonProps as ContentfulButtonProps } from "@shared/contentful/blocks/button/types";
7
+ import { useOutsideClick } from "@shared/hooks/use-outside-click";
8
+ import { cx } from "@shared/utils";
9
+
10
+ type ComponentButtonGroup = {
11
+ anchorId?: string | null;
12
+ title?: string | null;
13
+ items?: { items?: ContentfulButtonProps[] | null } | null;
14
+ };
15
+
16
+ type Link = ContentfulButtonProps | ComponentButtonGroup;
17
+
18
+ type LinkGroupsProps = {
19
+ link?: Link;
20
+ anchorName: string;
21
+ };
22
+
23
+ const isButton = (link: Link): link is ContentfulButtonProps => {
24
+ // If your group never has `href`, this is a simple and effective guard
25
+ return typeof (link as ContentfulButtonProps).href === "string";
26
+ };
27
+
28
+ export const DesktopLinkGroups: React.FC<LinkGroupsProps> = ({
29
+ link,
30
+ anchorName,
31
+ }) => {
32
+ const [isOpen, setIsOpen] = React.useState(false);
33
+
34
+ const ref = React.useRef<HTMLDivElement>(null);
35
+ useOutsideClick(ref, () => setIsOpen(false));
36
+
37
+ if (!link) return null;
38
+
39
+ // Single button
40
+ if (isButton(link)) {
41
+ return (
42
+ <Button
43
+ key={`submenu-link-btn-${link.anchorId}`}
44
+ {...link}
45
+ linkClassName="body3 flex items-center text-text h-full"
46
+ linkVariant="unstyled"
47
+ />
48
+ );
49
+ }
50
+
51
+ // Group
52
+ const { anchorId, title, items } = link;
53
+ const subMenu = Array.isArray(items?.items) ? items!.items! : [];
54
+ const fullAnchorName = `--link-anchor-${anchorName}`;
55
+
56
+ return (
57
+ <div
58
+ className="relative h-full"
59
+ style={{ anchorName: fullAnchorName } as CSSProperties}
60
+ ref={ref}
61
+ >
62
+ <Button
63
+ onClick={() => setIsOpen(prev => !prev)}
64
+ aria-expanded={isOpen}
65
+ buttonClassName="group body3 flex h-full text-text items-center"
66
+ key={anchorId}
67
+ showButtonAs="unstyled"
68
+ >
69
+ <Text as="span" className="group-hover:underline">
70
+ {title ?? null}
71
+ </Text>
72
+ <MaterialIcon
73
+ weight="200"
74
+ size={24}
75
+ className="text-icon-secondary group-hover:opacity-50"
76
+ name={isOpen ? "keyboard_arrow_up" : "keyboard_arrow_down"}
77
+ />
78
+ </Button>
79
+
80
+ <div
81
+ className={cx(
82
+ "shadow-navDrop fixed z-10 min-w-44 rounded-input-poppers border border-border bg-bg",
83
+ "transition-[opacity,transform] ease-out",
84
+ isOpen && subMenu.length > 0
85
+ ? "pointer-events-auto translate-y-0 opacity-100 duration-75"
86
+ : "pointer-events-none -translate-y-2 opacity-0 duration-0"
87
+ )}
88
+ style={
89
+ {
90
+ positionAnchor: fullAnchorName,
91
+ top: "anchor(bottom)",
92
+ left: "calc((anchor(left) + anchor(right)) / 2)",
93
+ translate: "-50% 0",
94
+ } as CSSProperties
95
+ }
96
+ >
97
+ <ul className="flex flex-col gap-2 py-2">
98
+ {subMenu.map((site, index) => {
99
+ return (
100
+ <li key={`submenu-link-${index}`} className="submenu-link">
101
+ <Button
102
+ {...site}
103
+ linkVariant="unstyled"
104
+ linkClassName="body3 px-4 hover:bg-bg-surface-hover flex items-center w-full h-11 text-text-link"
105
+ />
106
+ </li>
107
+ );
108
+ })}
109
+ </ul>
110
+ </div>
111
+ </div>
112
+ );
113
+ };