@ndla/ui 45.0.14 → 45.0.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/es/Article/Article.js +3 -3
  2. package/es/BlogPost/BlogPost.js +4 -4
  3. package/es/CampaignBlock/CampaignBlock.js +6 -6
  4. package/es/Embed/index.js +1 -1
  5. package/es/Frontpage/FrontpageMultidisciplinarySubject.js +7 -7
  6. package/es/Frontpage/FrontpageToolbox.js +4 -4
  7. package/es/FrontpageArticle/FrontpageArticle.js +3 -3
  8. package/es/InfoWidget/InfoWidget.js +8 -8
  9. package/es/LearningPaths/LearningPathInformation.js +4 -4
  10. package/es/LinkBlock/LinkBlock.js +6 -6
  11. package/es/MultidisciplinarySubject/MultidisciplinarySubject.js +7 -7
  12. package/es/Navigation/NavigationBox.js +20 -20
  13. package/es/Programme/Programme.js +6 -6
  14. package/es/RelatedArticleList/RelatedArticleV2.js +1 -1
  15. package/es/ResourceGroup/ResourceGroup.js +4 -4
  16. package/es/SectionHeading/SectionHeading.js +2 -2
  17. package/es/Subject/Subject.js +11 -11
  18. package/es/Subject/SubjectNewContent.js +8 -8
  19. package/es/Subject/SubjectSocial.js +2 -2
  20. package/es/ToolboxPage/ToolboxInfo.js +2 -2
  21. package/es/Topic/Topic.js +18 -18
  22. package/es/index.js +1 -2
  23. package/lib/Article/Article.js +4 -4
  24. package/lib/BlogPost/BlogPost.d.ts +1 -1
  25. package/lib/BlogPost/BlogPost.js +4 -4
  26. package/lib/CampaignBlock/CampaignBlock.d.ts +1 -1
  27. package/lib/CampaignBlock/CampaignBlock.js +6 -6
  28. package/lib/Embed/index.d.ts +1 -1
  29. package/lib/Embed/index.js +6 -0
  30. package/lib/Frontpage/FrontpageMultidisciplinarySubject.d.ts +1 -1
  31. package/lib/Frontpage/FrontpageMultidisciplinarySubject.js +7 -7
  32. package/lib/Frontpage/FrontpageToolbox.d.ts +1 -1
  33. package/lib/Frontpage/FrontpageToolbox.js +4 -4
  34. package/lib/FrontpageArticle/FrontpageArticle.js +4 -4
  35. package/lib/InfoWidget/InfoWidget.d.ts +1 -1
  36. package/lib/InfoWidget/InfoWidget.js +8 -8
  37. package/lib/LearningPaths/LearningPathInformation.js +5 -5
  38. package/lib/LinkBlock/LinkBlock.js +7 -7
  39. package/lib/MultidisciplinarySubject/MultidisciplinarySubject.js +8 -8
  40. package/lib/Navigation/NavigationBox.js +21 -21
  41. package/lib/Programme/Programme.js +7 -7
  42. package/lib/RelatedArticleList/RelatedArticleList.d.ts +1 -1
  43. package/lib/RelatedArticleList/RelatedArticleV2.d.ts +1 -1
  44. package/lib/RelatedArticleList/RelatedArticleV2.js +1 -1
  45. package/lib/ResourceGroup/ResourceGroup.d.ts +1 -1
  46. package/lib/ResourceGroup/ResourceGroup.js +4 -4
  47. package/lib/SectionHeading/SectionHeading.d.ts +1 -1
  48. package/lib/SectionHeading/SectionHeading.js +2 -2
  49. package/lib/Subject/Subject.d.ts +1 -1
  50. package/lib/Subject/Subject.js +11 -11
  51. package/lib/Subject/SubjectNewContent.d.ts +1 -1
  52. package/lib/Subject/SubjectNewContent.js +8 -8
  53. package/lib/Subject/SubjectSocial.d.ts +1 -1
  54. package/lib/Subject/SubjectSocial.js +2 -2
  55. package/lib/ToolboxPage/ToolboxInfo.js +3 -3
  56. package/lib/Topic/Topic.js +19 -19
  57. package/lib/index.d.ts +1 -3
  58. package/lib/index.js +6 -7
  59. package/lib/types.d.ts +0 -1
  60. package/package.json +17 -16
  61. package/src/Article/Article.tsx +1 -1
  62. package/src/BlogPost/BlogPost.tsx +1 -1
  63. package/src/CampaignBlock/CampaignBlock.tsx +1 -1
  64. package/src/Embed/index.ts +1 -1
  65. package/src/Frontpage/FrontpageMultidisciplinarySubject.tsx +1 -1
  66. package/src/Frontpage/FrontpageToolbox.tsx +1 -1
  67. package/src/FrontpageArticle/FrontpageArticle.tsx +1 -1
  68. package/src/InfoWidget/InfoWidget.tsx +1 -1
  69. package/src/LearningPaths/LearningPathInformation.tsx +1 -1
  70. package/src/LinkBlock/LinkBlock.tsx +1 -1
  71. package/src/MultidisciplinarySubject/MultidisciplinarySubject.tsx +1 -1
  72. package/src/Navigation/NavigationBox.tsx +1 -1
  73. package/src/Programme/Programme.tsx +1 -1
  74. package/src/RelatedArticleList/RelatedArticleList.tsx +1 -1
  75. package/src/RelatedArticleList/RelatedArticleV2.tsx +1 -1
  76. package/src/ResourceGroup/ResourceGroup.tsx +1 -1
  77. package/src/SectionHeading/SectionHeading.tsx +1 -1
  78. package/src/Subject/Subject.tsx +1 -1
  79. package/src/Subject/SubjectNewContent.tsx +1 -1
  80. package/src/Subject/SubjectSocial.tsx +1 -1
  81. package/src/ToolboxPage/ToolboxInfo.tsx +1 -1
  82. package/src/Topic/Topic.tsx +1 -1
  83. package/src/index.ts +1 -2
  84. package/src/types.ts +0 -2
  85. package/es/Typography/Heading.js +0 -48
  86. package/es/Typography/index.js +0 -9
  87. package/lib/Typography/Heading.d.ts +0 -25
  88. package/lib/Typography/Heading.js +0 -54
  89. package/lib/Typography/index.d.ts +0 -8
  90. package/lib/Typography/index.js +0 -13
  91. package/src/Typography/Heading.tsx +0 -96
  92. package/src/Typography/index.ts +0 -9
@@ -8,7 +8,7 @@ import { Switch } from '@ndla/switch';
8
8
  import { uuid } from '@ndla/util';
9
9
  import { useTranslation } from 'react-i18next';
10
10
  import { HumanMaleBoard } from '@ndla/icons/common';
11
- import { Heading } from '../Typography';
11
+ import { Heading } from '@ndla/typography';
12
12
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
13
13
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
14
14
  var StyledWrapper = /*#__PURE__*/_styled("nav", {
@@ -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":"AAYgC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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":"AAYgC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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,20 +32,20 @@ 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":"AAeuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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":"AAeuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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 StyledHeading = /*#__PURE__*/_styled(Heading, {
39
39
  target: "euu5u1510",
40
40
  label: "StyledHeading"
41
- })("&[data-inverted='true']{color:", colors.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqBqC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
41
+ })("&[data-inverted='true']{color:", colors.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqBqC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
42
42
  var _ref = process.env.NODE_ENV === "production" ? {
43
43
  name: "pw9pqe-StyledList",
44
44
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;"
45
45
  } : {
46
46
  name: "pw9pqe-StyledList",
47
47
  styles: "grid-template-columns:repeat(3, 1fr);label:StyledList;",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkDW","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAkDW","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  };
51
51
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -54,7 +54,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
54
54
  } : {
55
55
  name: "1df6ei-StyledList",
56
56
  styles: "display:grid;grid-template-columns:repeat(2, 1fr);label:StyledList;",
57
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAyCW","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */",
57
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAyCW","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
58
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
59
  };
60
60
  var StyledList = /*#__PURE__*/_styled("ul", {
@@ -65,28 +65,28 @@ var StyledList = /*#__PURE__*/_styled("ul", {
65
65
  from: breakpoints.tablet
66
66
  }), "{column-count:2;column-gap:20px;", props.direction === 'horizontal' && _ref2, ";}", mq.range({
67
67
  from: breakpoints.tabletWide
68
- }), "{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":"AAoCO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
+ }), "{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":"AAoCO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8BuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
70
70
  var StyledListItem = /*#__PURE__*/_styled("li", {
71
71
  target: "euu5u158",
72
72
  label: "StyledListItem"
73
73
  })("margin-bottom:0;break-inside:avoid;", function (props) {
74
74
  return props.listDirection === 'floating' && /*#__PURE__*/css("display:inline-block;margin:0 ", spacing.xsmall, " ", spacing.xsmall, " 0;", mq.range({
75
75
  until: breakpoints.mobileWide
76
- }), "{display:block;};label:StyledListItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqEO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
77
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAgEyD","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
76
+ }), "{display:block;};label:StyledListItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAqEO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
77
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAgEyD","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
78
78
  var StyledListElementWrapper = /*#__PURE__*/_styled("div", {
79
79
  target: "euu5u157",
80
80
  label: "StyledListElementWrapper"
81
81
  })("position:relative;", function (props) {
82
- 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":"AAkFO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
83
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8EoE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
82
+ 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":"AAkFO","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
83
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA8EoE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
84
84
  var StyledSpacingElement = /*#__PURE__*/_styled("span", {
85
85
  target: "euu5u156",
86
86
  label: "StyledSpacingElement"
87
87
  })("display:block;width:100%;height:2px;", mq.range({
88
88
  from: breakpoints.tablet
89
- }), "{height:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoGwC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
+ }), "{height:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoGwC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
90
90
  var StyledButtonContent = /*#__PURE__*/_styled("span", {
91
91
  target: "euu5u155",
92
92
  label: "StyledButtonContent"
@@ -96,7 +96,7 @@ var StyledButtonContent = /*#__PURE__*/_styled("span", {
96
96
  } : {
97
97
  name: "10g11oy",
98
98
  styles: "display:flex;width:100%;justify-content:space-between;align-items:center",
99
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA6GuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
99
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA6GuC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
100
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
101
  });
102
102
  var StyledButtonContentText = /*#__PURE__*/_styled("span", {
@@ -109,11 +109,11 @@ var StyledButtonContentText = /*#__PURE__*/_styled("span", {
109
109
  if (props.isAdditionalResource || props.isRestrictedResource) {
110
110
  return "padding-left: ".concat(spacing.small, ";");
111
111
  }
112
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoHoE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
112
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAoHoE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
113
113
  var StyledMarksWrapper = /*#__PURE__*/_styled("span", {
114
114
  target: "euu5u153",
115
115
  label: "StyledMarksWrapper"
116
- })("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":"AA+HsC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
116
+ })("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":"AA+HsC","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
117
117
  var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
118
118
  target: "euu5u152",
119
119
  label: "StyledAdditionalResourceMark"
@@ -121,7 +121,7 @@ var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
121
121
  return props.lighter && !props.selected ? "".concat(colors.brand.dark) : "".concat(colors.white);
122
122
  }, ";font-weight:600;font-size:12px;line-height:18px;text-align:center;display:inline-block;width:20px;height:20px;border:1px solid ", function (props) {
123
123
  return props.lighter && !props.selected ? "".concat(colors.brand.dark) : "".concat(colors.white);
124
- }, ";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":"AA4IyE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
+ }, ";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":"AA4IyE","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
125
125
  var StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
126
126
  target: "euu5u151",
127
127
  label: "StyledHumanBoardIconWrapper"
@@ -131,20 +131,20 @@ var StyledHumanBoardIconWrapper = /*#__PURE__*/_styled("span", {
131
131
  } : {
132
132
  name: "zjik7",
133
133
  styles: "display:flex",
134
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0J+C","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */",
134
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AA0J+C","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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
135
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
136
136
  });
137
137
  var StyledButtonContentSelected = /*#__PURE__*/_styled("span", {
138
138
  target: "euu5u150",
139
139
  label: "StyledButtonContentSelected"
140
- })("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":"AA6J+C","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */"));
140
+ })("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":"AA6J+C","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\n                    <StyledMarksWrapper>\n                      {item.isAdditionalResource && (\n                        <StyledAdditionalResourceMark lighter={colorMode === 'light'} selected={item.selected}>\n                          T\n                        </StyledAdditionalResourceMark>\n                      )}\n                      {item.isRestrictedResource && (\n                        <StyledHumanBoardIconWrapper>\n                          <HumanMaleBoard />\n                        </StyledHumanBoardIconWrapper>\n                      )}\n                    </StyledMarksWrapper>\n                    {item.label}\n                  </StyledButtonContentText>\n                  {item.selected && <StyledButtonContentSelected />}\n                </StyledButtonContent>\n              </ListElementType>\n            </StyledListElementWrapper>\n            {listDirection !== 'floating' && <StyledSpacingElement />}\n          </StyledListItem>\n        ))}\n      </StyledList>\n    </StyledWrapper>\n  );\n};\n\nexport default NavigationBox;\n"]} */"));
141
141
  var listElementStyle = process.env.NODE_ENV === "production" ? {
142
142
  name: "rknl6j-listElementStyle",
143
143
  styles: "display:flex;flex:1;text-align:left;label:listElementStyle;"
144
144
  } : {
145
145
  name: "rknl6j-listElementStyle",
146
146
  styles: "display:flex;flex:1;text-align:left;label:listElementStyle;",
147
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsK4B","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '../Typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */",
147
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NavigationBox.tsx"],"names":[],"mappings":"AAsK4B","file":"NavigationBox.tsx","sourcesContent":["import { MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, 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';\nimport { Heading } from '@ndla/typography';\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\nconst StyledHeading = styled(Heading)`\n  &[data-inverted='true'] {\n    color: ${colors.white};\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 && (\n          <StyledHeading element=\"h2\" margin=\"small\" headingStyle=\"list-title\" data-inverted={invertedStyle}>\n            {heading}\n          </StyledHeading>\n        )}\n        {hasAdditionalResources && (\n          <Switch\n            id={uuid()}\n            checked={showAdditionalResources}\n            label={t('navigation.additionalTopics')}\n            onChange={onToggleAdditionalResources}\n            css={invertedStyle ? { color: '#fff' } : {}}\n          />\n        )}\n      </StyledHeadingWrapper>\n      <StyledList data-testid=\"nav-box-list\" 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            >\n              <ListElementType\n                to={item.url ?? ''}\n                colorTheme={item.selected ? 'darker' : colorMode}\n                size=\"medium\"\n                shape=\"sharp\"\n                css={listElementStyle}\n                onClick={(e: MouseEvent<HTMLElement>) => {\n                  if (onClick) {\n                    onClick(e, item.id);\n                  }\n                }}\n              >\n                <StyledButtonContent>\n                  <StyledButtonContentText\n                    isAdditionalResource={item.isAdditionalResource}\n                    isRestrictedResource={item.isRestrictedResource}\n                    lighter={colorMode === 'light'}\n                  >\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"]} */",
148
148
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
149
149
  };
150
150
  export var NavigationBox = function NavigationBox(_ref3) {