@ndla/ui 33.3.1 → 33.3.3

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.
@@ -7,7 +7,7 @@ exports["default"] = exports.NavigationBox = void 0;
7
7
  var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _safelink = require("@ndla/safelink");
10
- var _button = _interopRequireDefault(require("@ndla/button"));
10
+ var _button = require("@ndla/button");
11
11
  var _core = require("@ndla/core");
12
12
  var _react2 = require("@emotion/react");
13
13
  var _switch = require("@ndla/switch");
@@ -26,7 +26,7 @@ var StyledWrapper = /*#__PURE__*/(0, _base["default"])("nav", {
26
26
  } : {
27
27
  name: "72u5pu",
28
28
  styles: "margin:20px 0 34px",
29
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAWgC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
29
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAWgC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
30
30
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
31
  });
32
32
  var StyledHeadingWrapper = /*#__PURE__*/(0, _base["default"])("div", {
@@ -38,7 +38,7 @@ var StyledHeadingWrapper = /*#__PURE__*/(0, _base["default"])("div", {
38
38
  } : {
39
39
  name: "1auicq3",
40
40
  styles: "display:flex;justify-content:space-between;align-items:baseline",
41
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAcuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
41
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAcuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
42
42
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
43
  });
44
44
  var _ref3 = process.env.NODE_ENV === "production" ? {
@@ -47,7 +47,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
47
47
  } : {
48
48
  name: "1qlx6tf-StyledHeading",
49
49
  styles: "color:#fff;label:StyledHeading;",
50
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
50
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
51
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
52
  };
53
53
  var StyledHeading = /*#__PURE__*/(0, _base["default"])("h2", {
@@ -55,14 +55,14 @@ var StyledHeading = /*#__PURE__*/(0, _base["default"])("h2", {
55
55
  label: "StyledHeading"
56
56
  })(_core.fonts.sizes('18px', '32px'), ";text-transform:uppercase;margin:0 0 10px;", function (props) {
57
57
  return props.invertedStyle && _ref3;
58
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwB8C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
58
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwB8C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
59
59
  var _ref = process.env.NODE_ENV === "production" ? {
60
60
  name: "pw9pqe-StyledList",
61
61
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;"
62
62
  } : {
63
63
  name: "pw9pqe-StyledList",
64
64
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;",
65
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0DW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\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":"AA0DW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\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
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -71,7 +71,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
71
71
  } : {
72
72
  name: "1df6ei-StyledList",
73
73
  styles: "display:grid;grid-template-columns:repeat(2, 1fr);label:StyledList;",
74
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAiDW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
74
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAiDW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
75
75
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
76
76
  };
77
77
  var StyledList = /*#__PURE__*/(0, _base["default"])("ul", {
@@ -82,28 +82,28 @@ var StyledList = /*#__PURE__*/(0, _base["default"])("ul", {
82
82
  from: _core.breakpoints.tablet
83
83
  }), "{column-count:2;column-gap:20px;", props.direction === 'horizontal' && _ref2, ";}", _core.mq.range({
84
84
  from: _core.breakpoints.tabletWide
85
- }), "{column-count:3;column-gap:20px;", props.direction === 'horizontal' && _ref, ";};label:StyledList;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4CO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
86
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsCuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
85
+ }), "{column-count:3;column-gap:20px;", props.direction === 'horizontal' && _ref, ";};label:StyledList;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4CO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
86
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsCuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
87
87
  var StyledListItem = /*#__PURE__*/(0, _base["default"])("li", {
88
88
  target: "euu5u158",
89
89
  label: "StyledListItem"
90
90
  })("margin-bottom:0;break-inside:avoid;", function (props) {
91
91
  return props.listDirection === 'floating' && /*#__PURE__*/(0, _react2.css)("display:inline-block;margin:0 ", _core.spacing.xsmall, " ", _core.spacing.xsmall, " 0;", _core.mq.range({
92
92
  until: _core.breakpoints.mobileWide
93
- }), "{display:block;};label:StyledListItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA6EO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
94
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwEyD","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
93
+ }), "{display:block;};label:StyledListItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA6EO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
94
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAwEyD","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
95
95
  var StyledListElementWrapper = /*#__PURE__*/(0, _base["default"])("div", {
96
96
  target: "euu5u157",
97
97
  label: "StyledListElementWrapper"
98
98
  })("position:relative;", function (props) {
99
- return props.isAdditionalResource && /*#__PURE__*/(0, _react2.css)("&>*{border:1px dashed ", props.lighter && !props.selected ? "".concat(_core.colors.brand.tertiary) : "".concat(_core.colors.brand.dark), ";background-clip:padding-box;:hover,:focus{border:1px dashed ", _core.colors.brand.dark, ";background-clip:padding-box;color:", _core.colors.white, ";", StyledAdditionalResourceMark, "{color:", _core.colors.white, ";border-color:", _core.colors.white, ";}}};label:StyledListElementWrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0FO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
100
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsFoE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
99
+ return props.isAdditionalResource && /*#__PURE__*/(0, _react2.css)("&>*{border:1px dashed ", props.lighter && !props.selected ? "".concat(_core.colors.brand.tertiary) : "".concat(_core.colors.brand.dark), ";background-clip:padding-box;:hover,:focus{border:1px dashed ", _core.colors.brand.dark, ";background-clip:padding-box;color:", _core.colors.white, ";", StyledAdditionalResourceMark, "{color:", _core.colors.white, ";border-color:", _core.colors.white, ";}}};label:StyledListElementWrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0FO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
100
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsFoE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
101
101
  var StyledSpacingElement = /*#__PURE__*/(0, _base["default"])("span", {
102
102
  target: "euu5u156",
103
103
  label: "StyledSpacingElement"
104
104
  })("display:block;width:100%;height:2px;", _core.mq.range({
105
105
  from: _core.breakpoints.tablet
106
- }), "{height:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4GwC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
106
+ }), "{height:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4GwC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
107
107
  var StyledButtonContent = /*#__PURE__*/(0, _base["default"])("span", {
108
108
  target: "euu5u155",
109
109
  label: "StyledButtonContent"
@@ -113,7 +113,7 @@ var StyledButtonContent = /*#__PURE__*/(0, _base["default"])("span", {
113
113
  } : {
114
114
  name: "10g11oy",
115
115
  styles: "display:flex;width:100%;justify-content:space-between;align-items:center",
116
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqHuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
116
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqHuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
117
117
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
118
118
  });
119
119
  var StyledButtonContentText = /*#__PURE__*/(0, _base["default"])("span", {
@@ -126,11 +126,11 @@ var StyledButtonContentText = /*#__PURE__*/(0, _base["default"])("span", {
126
126
  if (props.isAdditionalResource || props.isRestrictedResource) {
127
127
  return "padding-left: ".concat(_core.spacing.small, ";");
128
128
  }
129
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4HoE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
129
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA4HoE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
130
130
  var StyledMarksWrapper = /*#__PURE__*/(0, _base["default"])("span", {
131
131
  target: "euu5u153",
132
132
  label: "StyledMarksWrapper"
133
- })("position:absolute;left:7px;top:6px;display:flex;align-items:center;&>*{margin-left:", _core.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":"AAuIsC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
133
+ })("position:absolute;left:7px;top:6px;display:flex;align-items:center;&>*{margin-left:", _core.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":"AAuIsC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
134
134
  var StyledAdditionalResourceMark = /*#__PURE__*/(0, _base["default"])("span", {
135
135
  target: "euu5u152",
136
136
  label: "StyledAdditionalResourceMark"
@@ -138,7 +138,7 @@ var StyledAdditionalResourceMark = /*#__PURE__*/(0, _base["default"])("span", {
138
138
  return props.lighter && !props.selected ? "".concat(_core.colors.brand.dark) : "".concat(_core.colors.white);
139
139
  }, ";font-weight:600;font-size:12px;line-height:18px;text-align:center;display:inline-block;width:20px;height:20px;border:1px solid ", function (props) {
140
140
  return props.lighter && !props.selected ? "".concat(_core.colors.brand.dark) : "".concat(_core.colors.white);
141
- }, ";border-radius:100px;transition:", _core.misc.transition["default"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoJyE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
141
+ }, ";border-radius:100px;transition:", _core.misc.transition["default"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoJyE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
142
142
  var StyledHumanBoardIconWrapper = /*#__PURE__*/(0, _base["default"])("span", {
143
143
  target: "euu5u151",
144
144
  label: "StyledHumanBoardIconWrapper"
@@ -148,17 +148,26 @@ var StyledHumanBoardIconWrapper = /*#__PURE__*/(0, _base["default"])("span", {
148
148
  } : {
149
149
  name: "zjik7",
150
150
  styles: "display:flex",
151
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkK+C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
151
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkK+C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
152
152
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
153
153
  });
154
154
  var StyledButtonContentSelected = /*#__PURE__*/(0, _base["default"])("span", {
155
155
  target: "euu5u150",
156
156
  label: "StyledButtonContentSelected"
157
- })("width:10px;height:10px;border-radius:50%;background:", _core.colors.white, ";flex-shrink:0;margin-left:", _core.spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqK+C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport Button from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\n`;\n\nexport type ItemProps = {\n  url?: string;\n  label: string;\n  id?: string;\n  selected?: boolean;\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n};\ntype Props = {\n  heading?: string;\n  colorMode?: 'dark' | '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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'dark',\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 ? Button : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\n              <ListElementType\n                to={item.url ?? ''}\n                lighter={!item.selected && colorMode === 'light'}\n                greyLighter={!item.selected && colorMode === 'greyLighter'}\n                greyLightest={!item.selected && colorMode === 'greyLightest'}\n                darker={item.selected}\n                buttonSize=\"medium\"\n                size=\"medium\"\n                borderShape=\"sharpened\"\n                width=\"full\"\n                textAlign=\"left\"\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}>\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
157
+ })("width:10px;height:10px;border-radius:50%;background:", _core.colors.white, ";flex-shrink:0;margin-left:", _core.spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqK+C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
158
+ var listElementStyle = process.env.NODE_ENV === "production" ? {
159
+ name: "rknl6j-listElementStyle",
160
+ styles: "display:flex;flex:1;text-align:left;label:listElementStyle;"
161
+ } : {
162
+ name: "rknl6j-listElementStyle",
163
+ styles: "display:flex;flex:1;text-align:left;label:listElementStyle;",
164
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8K4B","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent, ChangeEventHandler } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { css } from '@emotion/react';\nimport { Switch } from '@ndla/switch';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { HumanMaleBoard } from '@ndla/icons/common';\n\nconst StyledWrapper = styled.nav`\n  margin: 20px 0 34px;\n`;\nconst StyledHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: baseline;\n`;\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst StyledHeading = styled.h2<InvertItProps>`\n  ${fonts.sizes('18px', '32px')};\n  text-transform: uppercase;\n  margin: 0 0 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\ntype listProps = {\n  direction?: 'horizontal' | 'vertical' | 'floating';\n};\nconst StyledList = styled.ul<listProps>`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${(props) =>\n    props.direction !== 'floating' &&\n    css`\n      ${mq.range({ from: breakpoints.tablet })} {\n        column-count: 2;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          display: grid;\n          grid-template-columns: repeat(2, 1fr);\n        `}\n      }\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        column-count: 3;\n        column-gap: 20px;\n        ${props.direction === 'horizontal' &&\n        css`\n          grid-template-columns: repeat(3, 1fr);\n        `}\n      }\n    `};\n`;\ntype additionalResourceProps = {\n  isAdditionalResource?: boolean;\n  isRestrictedResource?: boolean;\n  lighter?: boolean;\n  selected?: boolean;\n  listDirection?: listProps['direction'];\n};\n\nconst StyledListItem = styled.li<additionalResourceProps>`\n  margin-bottom: 0;\n  break-inside: avoid;\n  ${(props) =>\n    props.listDirection === 'floating' &&\n    css`\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 StyledListElementWrapper = styled.div<additionalResourceProps>`\n  position: relative;\n  ${(props) =>\n    props.isAdditionalResource &&\n    css`\n      & > * {\n        border: 1px dashed ${props.lighter && !props.selected ? `${colors.brand.tertiary}` : `${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          ${StyledAdditionalResourceMark} {\n            color: ${colors.white};\n            border-color: ${colors.white};\n          }\n        }\n      }\n    `}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 2px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 20px;\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<additionalResourceProps>`\n  ${(props) => {\n    if (props.isAdditionalResource && props.isRestrictedResource) {\n      return `padding-left: ${spacing.medium};`;\n    }\n    if (props.isAdditionalResource || props.isRestrictedResource) {\n      return `padding-left: ${spacing.small};`;\n    }\n  }}\n`;\n\nconst StyledMarksWrapper = styled.span`\n  position: absolute;\n  left: 7px;\n  top: 6px;\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`;\nconst StyledAdditionalResourceMark = styled.span<additionalResourceProps>`\n  color: ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  font-weight: 600;\n  font-size: 12px;\n  line-height: 18px;\n  text-align: center;\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${(props) => (props.lighter && !props.selected ? `${colors.brand.dark}` : `${colors.white}`)};\n  border-radius: 100px;\n  transition: ${misc.transition.default};\n`;\n\nconst StyledHumanBoardIconWrapper = styled.span`\n  display: flex;\n`;\nconst StyledButtonContentSelected = styled.span`\n  width: 10px;\n  height: 10px;\n  border-radius: 50%;\n  background: ${colors.white};\n  flex-shrink: 0;\n  margin-left: ${spacing.small};\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};\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?: listProps['direction'];\n  invertedStyle?: boolean;\n  onToggleAdditionalResources?: ChangeEventHandler<HTMLInputElement>;\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 && <StyledHeading invertedStyle={invertedStyle}>{heading}</StyledHeading>}\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\" direction={listDirection}>\n        {items.map((item: ItemProps) => (\n          <StyledListItem key={item.label} listDirection={listDirection} data-testid=\"nav-box-item\">\n            <StyledListElementWrapper\n              isAdditionalResource={item.isAdditionalResource}\n              lighter={colorMode === 'light'}\n              selected={item.selected}>\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                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}>\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\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            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
165
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
166
+ };
158
167
  var NavigationBox = function NavigationBox(_ref4) {
159
168
  var heading = _ref4.heading,
160
169
  _ref4$colorMode = _ref4.colorMode,
161
- colorMode = _ref4$colorMode === void 0 ? 'dark' : _ref4$colorMode,
170
+ colorMode = _ref4$colorMode === void 0 ? 'primary' : _ref4$colorMode,
162
171
  items = _ref4.items,
163
172
  isButtonElements = _ref4.isButtonElements,
164
173
  _onClick = _ref4.onClick,
@@ -172,7 +181,7 @@ var NavigationBox = function NavigationBox(_ref4) {
172
181
  onToggleAdditionalResources = _ref4$onToggleAdditio === void 0 ? function () {} : _ref4$onToggleAdditio;
173
182
  var _useTranslation = (0, _reactI18next.useTranslation)(),
174
183
  t = _useTranslation.t;
175
- var ListElementType = isButtonElements ? _button["default"] : _safelink.SafeLinkButton;
184
+ var ListElementType = isButtonElements ? _button.ButtonV2 : _safelink.SafeLinkButton;
176
185
  return (0, _jsxRuntime.jsxs)(StyledWrapper, {
177
186
  children: [(0, _jsxRuntime.jsxs)(StyledHeadingWrapper, {
178
187
  children: [heading && (0, _jsxRuntime.jsx)(StyledHeading, {
@@ -201,15 +210,10 @@ var NavigationBox = function NavigationBox(_ref4) {
201
210
  selected: item.selected,
202
211
  children: (0, _jsxRuntime.jsx)(ListElementType, {
203
212
  to: (_item$url = item.url) !== null && _item$url !== void 0 ? _item$url : '',
204
- lighter: !item.selected && colorMode === 'light',
205
- greyLighter: !item.selected && colorMode === 'greyLighter',
206
- greyLightest: !item.selected && colorMode === 'greyLightest',
207
- darker: item.selected,
208
- buttonSize: "medium",
213
+ colorTheme: item.selected ? 'darker' : colorMode,
209
214
  size: "medium",
210
- borderShape: "sharpened",
211
- width: "full",
212
- textAlign: "left",
215
+ shape: "sharp",
216
+ css: listElementStyle,
213
217
  onClick: function onClick(e) {
214
218
  if (_onClick) {
215
219
  _onClick(e, item.id);