@ndla/ui 50.8.3 → 50.9.1

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