@ndla/ui 34.3.1 → 34.3.2

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.
@@ -20,7 +20,7 @@ var StyledWrapper = /*#__PURE__*/_styled("nav", {
20
20
  } : {
21
21
  name: "72u5pu",
22
22
  styles: "margin:20px 0 34px",
23
- 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"]} */",
23
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAWgC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
24
24
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
25
25
  });
26
26
  var StyledHeadingWrapper = /*#__PURE__*/_styled("div", {
@@ -32,7 +32,7 @@ var StyledHeadingWrapper = /*#__PURE__*/_styled("div", {
32
32
  } : {
33
33
  name: "1auicq3",
34
34
  styles: "display:flex;justify-content:space-between;align-items:baseline",
35
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"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"]} */",
35
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAcuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
36
36
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
37
  });
38
38
  var _ref3 = process.env.NODE_ENV === "production" ? {
@@ -41,7 +41,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
41
41
  } : {
42
42
  name: "1qlx6tf-StyledHeading",
43
43
  styles: "color:#fff;label:StyledHeading;",
44
- 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"]} */",
44
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BO","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
45
45
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
46
46
  };
47
47
  var StyledHeading = /*#__PURE__*/_styled("h2", {
@@ -49,14 +49,14 @@ var StyledHeading = /*#__PURE__*/_styled("h2", {
49
49
  label: "StyledHeading"
50
50
  })(fonts.sizes('18px', '32px'), ";text-transform:uppercase;margin:0 0 10px;", function (props) {
51
51
  return props.invertedStyle && _ref3;
52
- }, ";" + (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"]} */"));
52
+ }, ";" + (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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
53
53
  var _ref = process.env.NODE_ENV === "production" ? {
54
54
  name: "pw9pqe-StyledList",
55
55
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;"
56
56
  } : {
57
57
  name: "pw9pqe-StyledList",
58
58
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;",
59
- 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"]} */",
59
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0DW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
60
60
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
61
61
  };
62
62
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -65,7 +65,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
65
65
  } : {
66
66
  name: "1df6ei-StyledList",
67
67
  styles: "display:grid;grid-template-columns:repeat(2, 1fr);label:StyledList;",
68
- 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"]} */",
68
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAiDW","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
69
69
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70
70
  };
71
71
  var StyledList = /*#__PURE__*/_styled("ul", {
@@ -76,28 +76,28 @@ var StyledList = /*#__PURE__*/_styled("ul", {
76
76
  from: breakpoints.tablet
77
77
  }), "{column-count:2;column-gap:20px;", props.direction === 'horizontal' && _ref2, ";}", mq.range({
78
78
  from: breakpoints.tabletWide
79
- }), "{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"]} */"));
80
- }, ";" + (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"]} */"));
79
+ }), "{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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
80
+ }, ";" + (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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
81
81
  var StyledListItem = /*#__PURE__*/_styled("li", {
82
82
  target: "euu5u158",
83
83
  label: "StyledListItem"
84
84
  })("margin-bottom:0;break-inside:avoid;", function (props) {
85
85
  return props.listDirection === 'floating' && /*#__PURE__*/css("display:inline-block;margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;", mq.range({
86
86
  until: breakpoints.mobileWide
87
- }), "{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"]} */"));
88
- }, ";" + (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"]} */"));
87
+ }), "{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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
88
+ }, ";" + (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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
89
89
  var StyledListElementWrapper = /*#__PURE__*/_styled("div", {
90
90
  target: "euu5u157",
91
91
  label: "StyledListElementWrapper"
92
92
  })("position:relative;", function (props) {
93
- return props.isAdditionalResource && /*#__PURE__*/css("&>*{border:1px dashed ", props.lighter && !props.selected ? "".concat(colors.brand.tertiary) : "".concat(colors.brand.dark), ";background-clip:padding-box;:hover,:focus{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;color:", colors.white, ";", StyledAdditionalResourceMark, "{color:", colors.white, ";border-color:", 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"]} */"));
94
- }, ";" + (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"]} */"));
93
+ return props.isAdditionalResource && /*#__PURE__*/css("&>*{border:1px dashed ", props.lighter && !props.selected ? "".concat(colors.brand.tertiary) : "".concat(colors.brand.dark), ";background-clip:padding-box;:hover,:focus{border:1px dashed ", colors.brand.dark, ";background-clip:padding-box;color:", colors.white, ";", StyledAdditionalResourceMark, "{color:", colors.white, ";border-color:", 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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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":"AAsFoE","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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 StyledSpacingElement = /*#__PURE__*/_styled("span", {
96
96
  target: "euu5u156",
97
97
  label: "StyledSpacingElement"
98
98
  })("display:block;width:100%;height:2px;", mq.range({
99
99
  from: breakpoints.tablet
100
- }), "{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"]} */"));
100
+ }), "{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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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 StyledButtonContent = /*#__PURE__*/_styled("span", {
102
102
  target: "euu5u155",
103
103
  label: "StyledButtonContent"
@@ -107,7 +107,7 @@ var StyledButtonContent = /*#__PURE__*/_styled("span", {
107
107
  } : {
108
108
  name: "10g11oy",
109
109
  styles: "display:flex;width:100%;justify-content:space-between;align-items:center",
110
- 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"]} */",
110
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqHuC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
111
111
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
112
112
  });
113
113
  var StyledButtonContentText = /*#__PURE__*/_styled("span", {
@@ -120,11 +120,11 @@ var StyledButtonContentText = /*#__PURE__*/_styled("span", {
120
120
  if (props.isAdditionalResource || props.isRestrictedResource) {
121
121
  return "padding-left: ".concat(spacing.small, ";");
122
122
  }
123
- }, ";" + (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"]} */"));
123
+ }, ";" + (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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
124
124
  var StyledMarksWrapper = /*#__PURE__*/_styled("span", {
125
125
  target: "euu5u153",
126
126
  label: "StyledMarksWrapper"
127
- })("position:absolute;left:7px;top:6px;display:flex;align-items:center;&>*{margin-left:", spacing.xxsmall, ";}span:first-of-type{margin-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"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"]} */"));
127
+ })("position:absolute;left:7px;top:6px;display:flex;align-items:center;&>*{margin-left:", spacing.xxsmall, ";}span:first-of-type{margin-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAuIsC","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
128
128
  var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
129
129
  target: "euu5u152",
130
130
  label: "StyledAdditionalResourceMark"
@@ -132,7 +132,7 @@ var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
132
132
  return props.lighter && !props.selected ? "".concat(colors.brand.dark) : "".concat(colors.white);
133
133
  }, ";font-weight:600;font-size:12px;line-height:18px;text-align:center;display:inline-block;width:20px;height:20px;border:1px solid ", function (props) {
134
134
  return props.lighter && !props.selected ? "".concat(colors.brand.dark) : "".concat(colors.white);
135
- }, ";border-radius:100px;transition:", 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"]} */"));
135
+ }, ";border-radius:100px;transition:", 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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */"));
136
136
  var StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
137
137
  target: "euu5u151",
138
138
  label: "StyledHumanBoardIconWrapper"
@@ -142,20 +142,20 @@ var StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
142
142
  } : {
143
143
  name: "zjik7",
144
144
  styles: "display:flex",
145
- 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"]} */",
145
+ 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 } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
146
146
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
147
147
  });
148
148
  var StyledButtonContentSelected = /*#__PURE__*/_styled("span", {
149
149
  target: "euu5u150",
150
150
  label: "StyledButtonContentSelected"
151
- })("width:10px;height:10px;border-radius:50%;background:", colors.white, ";flex-shrink:0;margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"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"]} */"));
151
+ })("width:10px;height:10px;border-radius:50%;background:", colors.white, ";flex-shrink:0;margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqK+C","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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
  var listElementStyle = process.env.NODE_ENV === "production" ? {
153
153
  name: "rknl6j-listElementStyle",
154
154
  styles: "display:flex;flex:1;text-align:left;label:listElementStyle;"
155
155
  } : {
156
156
  name: "rknl6j-listElementStyle",
157
157
  styles: "display:flex;flex:1;text-align:left;label:listElementStyle;",
158
- 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"]} */",
158
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8K4B","file":"NavigationBox.tsx","sourcesContent":["import React, { MouseEvent } 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?: (checked: boolean) => void;\n};\n\nexport const NavigationBox = ({\n  heading,\n  colorMode = 'primary',\n  items,\n  isButtonElements,\n  onClick,\n  hasAdditionalResources,\n  showAdditionalResources = false,\n  listDirection = 'horizontal',\n  invertedStyle,\n  onToggleAdditionalResources = () => {},\n}: Props) => {\n  const { t } = useTranslation();\n  const ListElementType = isButtonElements ? ButtonV2 : SafeLinkButton;\n  return (\n    <StyledWrapper>\n      <StyledHeadingWrapper>\n        {heading && <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"]} */",
159
159
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
160
160
  };
161
161
  export var NavigationBox = function NavigationBox(_ref4) {