@codecademy/brand 3.41.0-alpha.ec36a35d00.0 → 3.41.0

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.
@@ -1,194 +0,0 @@
1
- import _styled from "@emotion/styled/base";
2
- import { Anchor, Column, FlexBox, LayoutGrid, Text } from '@codecademy/gamut';
3
- import { Background, css } from '@codecademy/gamut-styles';
4
- import * as React from 'react';
5
- import { useEffect, useRef } from 'react';
6
- import { DescriptionSectionContainer, LayoutGridAntiAliased, useMegaMenuHeaderResponsiveStyles } from '../../shared';
7
- import { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
8
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
9
- const StyledColumn = /*#__PURE__*/_styled(Column, {
10
- target: "e1wdl1ig0",
11
- label: "StyledColumn"
12
- })(css({
13
- borderBottom: 1,
14
- borderColor: 'border-primary'
15
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderResourcesSection/index.tsx"],"names":[],"mappings":"AA0BqB","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderResourcesSection/index.tsx","sourcesContent":["import { Anchor, Column, FlexBox, LayoutGrid, Text } from '@codecademy/gamut';\nimport { Background, css } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport * as React from 'react';\nimport { RefObject, useEffect, useRef } from 'react';\n\nimport {\n  AppHeaderAction,\n  AppHeaderLinkItem,\n  AppHeaderResourcesDataItem,\n  DescriptionSectionContainer,\n  LayoutGridAntiAliased,\n  useMegaMenuHeaderResponsiveStyles,\n} from '../../shared';\nimport { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\n\nexport type AppHeaderResourcesSectionProps = AppHeaderAction & {\n  resources: AppHeaderResourcesDataItem[];\n  ref?: RefObject<HTMLUListElement>;\n  role?: string;\n  id?: string;\n  keyDownEvents?: (event: React.KeyboardEvent) => void;\n  isOpen?: boolean;\n  handleClose?: () => void;\n};\n\nconst StyledColumn = styled(Column)(\n  css({ borderBottom: 1, borderColor: 'border-primary' })\n);\n\nexport const AppHeaderResourcesSection = React.forwardRef<\n  HTMLDivElement,\n  AppHeaderResourcesSectionProps\n>(({ resources, action, isOpen, keyDownEvents, handleClose }, ref) => {\n  const tabIndex = isOpen === false ? -1 : 0;\n  const styles = useMegaMenuHeaderResponsiveStyles();\n  const { setFirstItemRef } = useAppHeaderDropdownContext();\n  const firstElemRef = useRef<HTMLAnchorElement>(null);\n\n  const onClick = (\n    event: React.MouseEvent<HTMLAnchorElement, MouseEvent>,\n    linkItem: AppHeaderLinkItem\n  ) => {\n    handleClose?.();\n    return action(event, linkItem);\n  };\n\n  useEffect(() => {\n    if (setFirstItemRef && firstElemRef.current) {\n      setFirstItemRef(firstElemRef.current);\n    }\n  }, [setFirstItemRef, firstElemRef]);\n\n  const DescriptionSection: React.FC<{\n    title: string;\n    subtitle?: string;\n  }> = ({ title, subtitle }) => (\n    <DescriptionSectionContainer\n      data-focusableresource=\"true\"\n      tabIndex={-1}\n      flexDirection=\"column\"\n    >\n      <Text\n        as=\"h2\"\n        variant=\"title-xs\"\n        pr={{ _: 96, md: 16 }}\n        mr={{ _: 96, md: 0 }}\n      >\n        {title}\n      </Text>\n      {subtitle && (\n        <Text fontSize={14} my={8}>\n          {subtitle}\n        </Text>\n      )}\n    </DescriptionSectionContainer>\n  );\n\n  return (\n    <LayoutGridAntiAliased onKeyDown={keyDownEvents} ref={ref} as=\"ul\" p={0}>\n      {resources.map((section, sectionIndex) => {\n        const { title, description, links, data } = section;\n        const borderBottom = sectionIndex === resources.length - 1 ? 'none' : 1;\n\n        return (\n          <StyledColumn size={12} key={title} as=\"li\">\n            <LayoutGrid>\n              <Column size={{ xs: 12, md: 3 }}>\n                <Background\n                  {...styles}\n                  px={{ _: 16, xs: 32 }}\n                  py={{ _: 16, sm: 24 }}\n                  borderBottom={borderBottom}\n                >\n                  <DescriptionSection title={title} subtitle={description} />\n                  {links && (\n                    <FlexBox flexDirection=\"column\" alignItems=\"flex-start\">\n                      {links.map((link, linkIndex) => {\n                        return (\n                          <Anchor\n                            variant=\"standard\"\n                            fontSize={14}\n                            fontWeight={700}\n                            textAlign={{ _: 'center', md: 'left' }}\n                            href={link.href}\n                            data-focusableresource=\"true\"\n                            onClick={(\n                              event: React.MouseEvent<HTMLAnchorElement>\n                            ) => onClick(event, link)}\n                            tabIndex={tabIndex}\n                            mt={{ _: 16, lg: description ? 16 : 24 }}\n                            target={link.newTab ? '_blank' : '_self'}\n                            key={link.id}\n                            ref={\n                              sectionIndex === 0 && linkIndex === 0\n                                ? firstElemRef\n                                : undefined\n                            }\n                          >\n                            {link.text}\n                            <span aria-hidden>&nbsp;→</span>\n                          </Anchor>\n                        );\n                      })}\n                    </FlexBox>\n                  )}\n                </Background>\n              </Column>\n              <Column size={{ xs: 12, md: 8 }}>\n                <LayoutGrid\n                  as=\"ul\"\n                  pt={32}\n                  pb={24}\n                  pl={{ _: 16, sm: 64, md: 48 }}\n                >\n                  {data.map((item) => {\n                    const { id, href, text, badge, newTab } = item;\n\n                    return (\n                      <Column as=\"li\" key={id} size={{ _: 12, lg: 4 }}>\n                        <Anchor\n                          data-focusableresource=\"true\"\n                          variant=\"interface\"\n                          href={href}\n                          onClick={(\n                            event: React.MouseEvent<HTMLAnchorElement>\n                          ) => onClick(event, item)}\n                          tabIndex={tabIndex}\n                          target={newTab ? '_blank' : '_self'}\n                        >\n                          {'description' in item ? (\n                            <>\n                              <FlexBox whiteSpace=\"nowrap\">\n                                <Text\n                                  fontSize={16}\n                                  fontWeight=\"bold\"\n                                  as=\"h3\"\n                                  pb={4}\n                                >\n                                  {text}\n                                </Text>\n                                {badge}\n                              </FlexBox>\n                              <Text fontSize={14} pb={24} pr={40}>\n                                {item.description}\n                              </Text>\n                            </>\n                          ) : (\n                            <Text fontSize={16} pb={8}>\n                              {text}\n                            </Text>\n                          )}\n                        </Anchor>\n                      </Column>\n                    );\n                  })}\n                </LayoutGrid>\n              </Column>\n            </LayoutGrid>\n          </StyledColumn>\n        );\n      })}\n    </LayoutGridAntiAliased>\n  );\n});\n"]} */");
16
- export const AppHeaderResourcesSection = /*#__PURE__*/React.forwardRef(({
17
- resources,
18
- action,
19
- isOpen,
20
- keyDownEvents,
21
- handleClose
22
- }, ref) => {
23
- const tabIndex = isOpen === false ? -1 : 0;
24
- const styles = useMegaMenuHeaderResponsiveStyles();
25
- const {
26
- setFirstItemRef
27
- } = useAppHeaderDropdownContext();
28
- const firstElemRef = useRef(null);
29
- const onClick = (event, linkItem) => {
30
- handleClose?.();
31
- return action(event, linkItem);
32
- };
33
- useEffect(() => {
34
- if (setFirstItemRef && firstElemRef.current) {
35
- setFirstItemRef(firstElemRef.current);
36
- }
37
- }, [setFirstItemRef, firstElemRef]);
38
- const DescriptionSection = ({
39
- title,
40
- subtitle
41
- }) => /*#__PURE__*/_jsxs(DescriptionSectionContainer, {
42
- "data-focusableresource": "true",
43
- tabIndex: -1,
44
- flexDirection: "column",
45
- children: [/*#__PURE__*/_jsx(Text, {
46
- as: "h2",
47
- variant: "title-xs",
48
- pr: {
49
- _: 96,
50
- md: 16
51
- },
52
- mr: {
53
- _: 96,
54
- md: 0
55
- },
56
- children: title
57
- }), subtitle && /*#__PURE__*/_jsx(Text, {
58
- fontSize: 14,
59
- my: 8,
60
- children: subtitle
61
- })]
62
- });
63
- return /*#__PURE__*/_jsx(LayoutGridAntiAliased, {
64
- onKeyDown: keyDownEvents,
65
- ref: ref,
66
- as: "ul",
67
- p: 0,
68
- children: resources.map((section, sectionIndex) => {
69
- const {
70
- title,
71
- description,
72
- links,
73
- data
74
- } = section;
75
- const borderBottom = sectionIndex === resources.length - 1 ? 'none' : 1;
76
- return /*#__PURE__*/_jsx(StyledColumn, {
77
- size: 12,
78
- as: "li",
79
- children: /*#__PURE__*/_jsxs(LayoutGrid, {
80
- children: [/*#__PURE__*/_jsx(Column, {
81
- size: {
82
- xs: 12,
83
- md: 3
84
- },
85
- children: /*#__PURE__*/_jsxs(Background, {
86
- ...styles,
87
- px: {
88
- _: 16,
89
- xs: 32
90
- },
91
- py: {
92
- _: 16,
93
- sm: 24
94
- },
95
- borderBottom: borderBottom,
96
- children: [/*#__PURE__*/_jsx(DescriptionSection, {
97
- title: title,
98
- subtitle: description
99
- }), links && /*#__PURE__*/_jsx(FlexBox, {
100
- flexDirection: "column",
101
- alignItems: "flex-start",
102
- children: links.map((link, linkIndex) => {
103
- return /*#__PURE__*/_jsxs(Anchor, {
104
- variant: "standard",
105
- fontSize: 14,
106
- fontWeight: 700,
107
- textAlign: {
108
- _: 'center',
109
- md: 'left'
110
- },
111
- href: link.href,
112
- "data-focusableresource": "true",
113
- onClick: event => onClick(event, link),
114
- tabIndex: tabIndex,
115
- mt: {
116
- _: 16,
117
- lg: description ? 16 : 24
118
- },
119
- target: link.newTab ? '_blank' : '_self',
120
- ref: sectionIndex === 0 && linkIndex === 0 ? firstElemRef : undefined,
121
- children: [link.text, /*#__PURE__*/_jsx("span", {
122
- "aria-hidden": true,
123
- children: "\xA0\u2192"
124
- })]
125
- }, link.id);
126
- })
127
- })]
128
- })
129
- }), /*#__PURE__*/_jsx(Column, {
130
- size: {
131
- xs: 12,
132
- md: 8
133
- },
134
- children: /*#__PURE__*/_jsx(LayoutGrid, {
135
- as: "ul",
136
- pt: 32,
137
- pb: 24,
138
- pl: {
139
- _: 16,
140
- sm: 64,
141
- md: 48
142
- },
143
- children: data.map(item => {
144
- const {
145
- id,
146
- href,
147
- text,
148
- badge,
149
- newTab
150
- } = item;
151
- return /*#__PURE__*/_jsx(Column, {
152
- as: "li",
153
- size: {
154
- _: 12,
155
- lg: 4
156
- },
157
- children: /*#__PURE__*/_jsx(Anchor, {
158
- "data-focusableresource": "true",
159
- variant: "interface",
160
- href: href,
161
- onClick: event => onClick(event, item),
162
- tabIndex: tabIndex,
163
- target: newTab ? '_blank' : '_self',
164
- children: 'description' in item ? /*#__PURE__*/_jsxs(_Fragment, {
165
- children: [/*#__PURE__*/_jsxs(FlexBox, {
166
- whiteSpace: "nowrap",
167
- children: [/*#__PURE__*/_jsx(Text, {
168
- fontSize: 16,
169
- fontWeight: "bold",
170
- as: "h3",
171
- pb: 4,
172
- children: text
173
- }), badge]
174
- }), /*#__PURE__*/_jsx(Text, {
175
- fontSize: 14,
176
- pb: 24,
177
- pr: 40,
178
- children: item.description
179
- })]
180
- }) : /*#__PURE__*/_jsx(Text, {
181
- fontSize: 16,
182
- pb: 8,
183
- children: text
184
- })
185
- })
186
- }, id);
187
- })
188
- })
189
- })]
190
- })
191
- }, title);
192
- })
193
- });
194
- });