@ndla/ui 50.9.3 → 50.9.5
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/es/Footer/Footer.js +15 -11
- package/es/Footer/FooterLinks.js +12 -9
- package/es/Navigation/NavigationBox.js +14 -14
- package/es/all.css +1 -1
- package/lib/Footer/Footer.js +15 -11
- package/lib/Footer/FooterLinks.js +12 -9
- package/lib/Navigation/NavigationBox.js +14 -14
- package/lib/all.css +1 -1
- package/package.json +17 -17
- package/src/Footer/Footer.tsx +5 -2
- package/src/Footer/FooterLinks.tsx +6 -4
- package/src/Navigation/NavigationBox.tsx +2 -2
|
@@ -22,7 +22,7 @@ import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
|
22
22
|
const StyledWrapper = /*#__PURE__*/_styled("nav", {
|
|
23
23
|
target: "euu5u1511",
|
|
24
24
|
label: "StyledWrapper"
|
|
25
|
-
})("margin:", spacing.normal, " 0 ", spacing.mediumlarge, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoBgC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
25
|
+
})("margin:", spacing.normal, " 0 ", spacing.mediumlarge, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoBgC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
26
26
|
const StyledHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
27
27
|
target: "euu5u1510",
|
|
28
28
|
label: "StyledHeadingWrapper"
|
|
@@ -32,27 +32,27 @@ const StyledHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
|
32
32
|
} : {
|
|
33
33
|
name: "1auicq3",
|
|
34
34
|
styles: "display:flex;justify-content:space-between;align-items:baseline",
|
|
35
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwBuC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
35
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwBuC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
36
36
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
37
37
|
});
|
|
38
38
|
const StyledHeading = /*#__PURE__*/_styled(Heading, {
|
|
39
39
|
target: "euu5u159",
|
|
40
40
|
label: "StyledHeading"
|
|
41
|
-
})("&[data-inverted=\"true\"]{color:", colors.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BqC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
41
|
+
})("&[data-inverted=\"true\"]{color:", colors.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BqC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
42
42
|
const StyledList = /*#__PURE__*/_styled("ul", {
|
|
43
43
|
target: "euu5u158",
|
|
44
44
|
label: "StyledList"
|
|
45
|
-
})("list-style:none;padding:0;
|
|
45
|
+
})("list-style:none;padding:0;gap:", spacing.xxsmall, ";&[data-direction=\"horizontal\"]{display:flex;flex-direction:column;", mq.range({
|
|
46
46
|
from: breakpoints.tablet
|
|
47
47
|
}), "{column-count:2;gap:20px;display:grid;grid-template-columns:repeat(2, 1fr);}", mq.range({
|
|
48
48
|
from: breakpoints.tabletWide
|
|
49
|
-
}), "{column-count:3;gap:20px;grid-template-columns:repeat(3, 1fr);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoC4B","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
49
|
+
}), "{column-count:3;gap:20px;grid-template-columns:repeat(3, 1fr);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoC4B","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
50
50
|
const StyledListItem = /*#__PURE__*/_styled("li", {
|
|
51
51
|
target: "euu5u157",
|
|
52
52
|
label: "StyledListItem"
|
|
53
53
|
})("padding:0;break-inside:avoid;&[data-direction=\"floating\"]{display:inline-block;margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;", mq.range({
|
|
54
54
|
until: breakpoints.mobileWide
|
|
55
|
-
}), "{display:block;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0DgC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
55
|
+
}), "{display:block;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0DgC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
56
56
|
const StyledButtonContent = /*#__PURE__*/_styled("span", {
|
|
57
57
|
target: "euu5u156",
|
|
58
58
|
label: "StyledButtonContent"
|
|
@@ -62,21 +62,21 @@ const StyledButtonContent = /*#__PURE__*/_styled("span", {
|
|
|
62
62
|
} : {
|
|
63
63
|
name: "10g11oy",
|
|
64
64
|
styles: "display:flex;width:100%;justify-content:space-between;align-items:center",
|
|
65
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAuEuC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
65
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAuEuC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
66
66
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
67
67
|
});
|
|
68
68
|
const StyledButtonContentText = /*#__PURE__*/_styled("span", {
|
|
69
69
|
target: "euu5u155",
|
|
70
70
|
label: "StyledButtonContentText"
|
|
71
|
-
})("&[data-additional=\"true\"][data-restricted=\"true\"]{padding-left:", spacing.medium, ";}&[data-additional=\"true\"]{padding-left:", spacing.small, ";}&[data-restricted=\"true\"]{padding-left:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8E2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
71
|
+
})("&[data-additional=\"true\"][data-restricted=\"true\"]{padding-left:", spacing.medium, ";}&[data-additional=\"true\"]{padding-left:", spacing.small, ";}&[data-restricted=\"true\"]{padding-left:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8E2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
72
72
|
const StyledMarksWrapper = /*#__PURE__*/_styled("span", {
|
|
73
73
|
target: "euu5u154",
|
|
74
74
|
label: "StyledMarksWrapper"
|
|
75
|
-
})("position:absolute;left:", spacing.xxsmall, ";top:", spacing.xsmall, ";display:flex;align-items:center;&>*{margin-left:", spacing.xxsmall, ";}span:first-of-type{margin-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0FsC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
75
|
+
})("position:absolute;left:", spacing.xxsmall, ";top:", spacing.xsmall, ";display:flex;align-items:center;&>*{margin-left:", spacing.xxsmall, ";}span:first-of-type{margin-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0FsC","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
76
76
|
const StyledAdditional = /*#__PURE__*/_styled(Additional, {
|
|
77
77
|
target: "euu5u153",
|
|
78
78
|
label: "StyledAdditional"
|
|
79
|
-
})("fill:", colors.white, ";width:", spacing.nsmall, ";height:", spacing.nsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwG2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
79
|
+
})("fill:", colors.white, ";width:", spacing.nsmall, ";height:", spacing.nsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwG2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
80
80
|
const StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
|
|
81
81
|
target: "euu5u152",
|
|
82
82
|
label: "StyledHumanBoardIconWrapper"
|
|
@@ -86,24 +86,24 @@ const StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
|
|
|
86
86
|
} : {
|
|
87
87
|
name: "zjik7",
|
|
88
88
|
styles: "display:flex",
|
|
89
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8G+C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
89
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8G+C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
90
90
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
91
91
|
});
|
|
92
92
|
const StyledButtonContentSelected = /*#__PURE__*/_styled("span", {
|
|
93
93
|
target: "euu5u151",
|
|
94
94
|
label: "StyledButtonContentSelected"
|
|
95
|
-
})("width:10px;height:10px;border-radius:", misc.borderRadiusLarge, ";background:", colors.white, ";flex-shrink:0;margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkH+C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
95
|
+
})("width:10px;height:10px;border-radius:", misc.borderRadiusLarge, ";background:", colors.white, ";flex-shrink:0;margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkH+C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
96
96
|
const StyledListElementWrapper = /*#__PURE__*/_styled("div", {
|
|
97
97
|
target: "euu5u150",
|
|
98
98
|
label: "StyledListElementWrapper"
|
|
99
|
-
})("position:relative;&[data-additional=\"true\"]{&>*{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;:hover,:focus{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;color:", colors.white, ";}&[data-color-mode=\"light\"][data-selected=\"false\"]{border:1px dashed ", colors.brand.tertiary, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA2H2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
99
|
+
})("position:relative;&[data-additional=\"true\"]{&>*{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;:hover,:focus{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;color:", colors.white, ";}&[data-color-mode=\"light\"][data-selected=\"false\"]{border:1px dashed ", colors.brand.tertiary, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA2H2C","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
|
|
100
100
|
const listElementStyle = process.env.NODE_ENV === "production" ? {
|
|
101
101
|
name: "rknl6j-listElementStyle",
|
|
102
102
|
styles: "display:flex;flex:1;text-align:left;label:listElementStyle;"
|
|
103
103
|
} : {
|
|
104
104
|
name: "rknl6j-listElementStyle",
|
|
105
105
|
styles: "display:flex;flex:1;text-align:left;label:listElementStyle;",
|
|
106
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8I4B","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
106
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8I4B","file":"NavigationBox.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { MouseEvent } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, HumanMaleBoard } from \"@ndla/icons/common\";\nimport { SafeLinkButton } from \"@ndla/safelink\";\nimport { Switch } from \"@ndla/switch\";\nimport { Heading } from \"@ndla/typography\";\nimport { uuid } from \"@ndla/util\";\n\nconst StyledWrapper = styled.nav`\n  margin: ${spacing.normal} 0 ${spacing.mediumlarge};\n`;\n\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\nconst StyledHeading = styled(Heading)`\n  &[data-inverted=\"true\"] {\n    color: ${colors.white};\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  padding: 0;\n  gap: ${spacing.xxsmall};\n\n  &[data-direction=\"horizontal\"] {\n    display: flex;\n    flex-direction: column;\n    ${mq.range({ from: breakpoints.tablet })} {\n      column-count: 2;\n      gap: 20px;\n      display: grid;\n      grid-template-columns: repeat(2, 1fr);\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      column-count: 3;\n      gap: 20px;\n      grid-template-columns: repeat(3, 1fr);\n    }\n  }\n`;\n\nconst StyledListItem = styled.li`\n  padding: 0;\n  break-inside: avoid;\n\n  &[data-direction=\"floating\"] {\n    display: inline-block;\n    margin: 0 ${spacing.xsmall} ${spacing.xsmall} 0;\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n  }\n`;\n\nconst StyledButtonContent = styled.span`\n  display: flex;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n`;\n\nconst StyledButtonContentText = styled.span`\n  &[data-additional=\"true\"][data-restricted=\"true\"] {\n    padding-left: ${spacing.medium};\n  }\n  &[data-additional=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n  &[data-restricted=\"true\"] {\n    padding-left: ${spacing.small};\n  }\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: ${spacing.xxsmall};\n  top: ${spacing.xsmall};\n  display: flex;\n  align-items: center;\n  & > * {\n    margin-left: ${spacing.xxsmall};\n  }\n  span:first-of-type {\n    margin-left: 0;\n  }\n`;\n\nconst StyledAdditional = styled(Additional)`\n  fill: ${colors.white};\n  width: ${spacing.nsmall};\n  height: ${spacing.nsmall};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\n\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: ${misc.borderRadiusLarge};\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nconst StyledListElementWrapper = styled.div`\n  position: relative;\n  &[data-additional=\"true\"] {\n    & > * {\n      border: 1px dashed ${colors.brand.dark};\n      background-clip: padding-box;\n      :hover,\n      :focus {\n        border: 1px dashed ${colors.brand.dark};\n        background-clip: padding-box;\n        color: ${colors.white};\n      }\n      &[data-color-mode=\"light\"][data-selected=\"false\"] {\n        border: 1px dashed ${colors.brand.tertiary};\n      }\n    }\n  }\n`;\n\nconst listElementStyle = css`\n  display: flex;\n  flex: 1;\n  text-align: left;\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\n\ntype Props = {\n  heading?: string;\n  colorMode?: \"primary\" | \"darker\" | \"light\" | \"greyLightest\" | \"greyLighter\";\n  isButtonElements?: boolean;\n  items?: ItemProps[];\n  onClick?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  hasAdditionalResources?: boolean;\n  showAdditionalResources?: boolean;\n  listDirection?: \"horizontal\" | \"floating\";\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = \"primary\",\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = \"horizontal\",\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t(\"navigation.additionalTopics\")}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: \"#fff\" } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" data-direction={listDirection}>\n        {items?.map((item: ItemProps) => (\n          <StyledListItem key={item.label} data-direction={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              data-additional={item.isAdditionalResource}\n              data-color-mode={colorMode}\n              data-selected={item.selected}\n            >\n              <ListElementType\n                to={item.url ?? \"\"}\n                colorTheme={item.selected ? \"darker\" : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    data-additional={item.isAdditionalResource}\n                    data-restricted={item.isRestrictedResource}\n                    data-color-mode={colorMode}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditional aria-label={t(\"resource.additionalTooltip\")} ariaHidden={false} />\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
|
|
107
107
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
108
108
|
};
|
|
109
109
|
export const NavigationBox = _ref => {
|