@ndla/ui 50.6.2 → 50.6.4

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.
@@ -68,7 +68,7 @@ const ListElement = /*#__PURE__*/(0, _base.default)("li", {
68
68
  label: "ListElement"
69
69
  })("border:1px solid ", _core.colors.brand.neutral7, ";border-radius:", _core.misc.borderRadius, ";background:", _core.colors.white, ";margin-bottom:", _core.spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", _core.spacing.small, ";&[data-additional='true']{border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";}*{transition:height ease-out 0.2s,width ease-out 0.2s;}&[data-active='true']{&:before{", _core.mq.range({
70
70
  from: _core.breakpoints.tablet
71
- }), "{content:'';display:block;position:absolute;width:", _core.spacing.small, ";height:", _core.spacing.small, ";border-radius:100%;transform:translate(-", _core.spacing.mediumlarge, ");background-color:var(--contentTypeBg);}}}&[hidden]{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4D6B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
71
+ }), "{content:'';display:block;position:absolute;width:", _core.spacing.small, ";height:", _core.spacing.small, ";border-radius:100%;transform:translate(-", _core.spacing.mediumlarge, ");background-color:var(--contentTypeBg);}}}&[hidden]{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4D6B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
72
72
  const ResourceLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
73
73
  target: "ehgdkrx7",
74
74
  label: "ResourceLink"
@@ -76,7 +76,7 @@ const ResourceLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
76
76
  from: _core.breakpoints.tablet
77
77
  }), "{", _core.fonts.sizes('18px', '26px'), ";}", _core.mq.range({
78
78
  from: _core.breakpoints.desktop
79
- }), "{", _core.fonts.sizes('20px', '26px'), ";}&:hover{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoGqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
79
+ }), "{", _core.fonts.sizes('20px', '26px'), ";}&:hover{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoGqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
80
80
  const ContentBadgeWrapper = /*#__PURE__*/(0, _base.default)("div", {
81
81
  target: "ehgdkrx6",
82
82
  label: "ContentBadgeWrapper"
@@ -84,15 +84,15 @@ const ContentBadgeWrapper = /*#__PURE__*/(0, _base.default)("div", {
84
84
  from: _core.breakpoints.tablet
85
85
  }), "{padding-right:", _core.spacing.small, ";padding-left:", _core.spacing.xsmall, ";}", _core.mq.range({
86
86
  from: _core.breakpoints.desktop
87
- }), "{padding-right:", _core.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAsHsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
87
+ }), "{padding-right:", _core.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAsHsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
88
88
  const TypeWrapper = /*#__PURE__*/(0, _base.default)("div", {
89
89
  target: "ehgdkrx5",
90
90
  label: "TypeWrapper"
91
- })("display:flex;align-items:center;gap:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAyI8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
91
+ })("display:flex;align-items:center;gap:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAyI8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
92
92
  const ContentTypeName = /*#__PURE__*/(0, _base.default)("span", {
93
93
  target: "ehgdkrx4",
94
94
  label: "ContentTypeName"
95
- })("font-family:", _core.fonts.sans, ";", _core.fonts.sizes('14px', '18px'), ";font-weight:", _core.fonts.weight.semibold, ";color:", _core.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+ImC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
95
+ })("font-family:", _core.fonts.sans, ";", _core.fonts.sizes('14px', '18px'), ";font-weight:", _core.fonts.weight.semibold, ";color:", _core.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+ImC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
96
96
  const InlineContainer = /*#__PURE__*/(0, _base.default)("div", {
97
97
  target: "ehgdkrx3",
98
98
  label: "InlineContainer"
@@ -102,17 +102,17 @@ const InlineContainer = /*#__PURE__*/(0, _base.default)("div", {
102
102
  } : {
103
103
  name: "1u4hpl4",
104
104
  styles: "display:inline",
105
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAuJkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAuJkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
106
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
107
  });
108
108
  const ResourceWrapper = /*#__PURE__*/(0, _base.default)("div", {
109
109
  target: "ehgdkrx2",
110
110
  label: "ResourceWrapper"
111
- })("display:flex;gap:", _core.spacing.xsmall, ";align-items:center;:hover{[data-badge]{width:38px;height:38px;svg{width:20px;height:20px;}[data-type='subject-material'],[data-type='learning-path'],[data-type='source-material'],[data-type='external-learning-resources']{svg{width:26px;height:26px;}}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA2JkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
111
+ })("display:flex;gap:", _core.spacing.xsmall, ";align-items:center;:hover{[data-badge]{width:38px;height:38px;svg{width:20px;height:20px;}[data-type='subject-material'],[data-type='learning-path'],[data-type='source-material'],[data-type='external-learning-resources']{svg{width:26px;height:26px;}}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA2JkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
112
112
  const CurrentSmall = /*#__PURE__*/(0, _base.default)("small", {
113
113
  target: "ehgdkrx1",
114
114
  label: "CurrentSmall"
115
- })("margin-left:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqLiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
115
+ })("margin-left:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqLiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
116
116
  const IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
117
117
  target: "ehgdkrx0",
118
118
  label: "IconWrapper"
@@ -122,7 +122,7 @@ const IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
122
122
  } : {
123
123
  name: "ji2k1n",
124
124
  styles: "display:flex;flex-grow:1;svg{width:26px;height:26px;}",
125
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqM8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
125
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqM8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\nimport { Resource } from '../types';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    [data-badge] {\n      width: 38px;\n      height: 38px;\n\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n      [data-type='subject-material'],\n      [data-type='learning-path'],\n      [data-type='source-material'],\n      [data-type='external-learning-resources'] {\n        svg {\n          width: 26px;\n          height: 26px;\n        }\n      }\n    }\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink\n            to={path}\n            lang={language === 'nb' ? 'no' : language}\n            aria-current={active ? 'page' : undefined}\n            aria-describedby={describedBy}\n          >\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
126
126
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
127
127
  });
128
128
  const ResourceItem = _ref => {
@@ -170,7 +170,7 @@ const ResourceItem = _ref => {
170
170
  }), (0, _jsxRuntime.jsxs)(InlineContainer, {
171
171
  children: [(0, _jsxRuntime.jsx)(ResourceLink, {
172
172
  to: path,
173
- lang: language,
173
+ lang: language === 'nb' ? 'no' : language,
174
174
  "aria-current": active ? 'page' : undefined,
175
175
  "aria-describedby": describedBy,
176
176
  children: name
@@ -1031,7 +1031,7 @@ const messages = {
1031
1031
  markAll: 'Mark all as read',
1032
1032
  subscribe: 'You will now be notified of new replies to this topic',
1033
1033
  unsubscribe: 'You have turned off notification of new replies to this topic',
1034
- commentedOn: 'commented on the post <i>{{title}}</i> which you follow'
1034
+ commentedOn: 'commented on the post <i>{{title}}</i>'
1035
1035
  },
1036
1036
  topicsBy: 'Topics by'
1037
1037
  },
@@ -1120,7 +1120,7 @@ const messages = {
1120
1120
  feide: 'We have retrieved this information from Feide',
1121
1121
  feideWrongInfo: 'If the information is incorrect, it has to be updated by the host organizationg or the school that the account is associated with. An overview of user support can be found here: feide.no/brukerstotte',
1122
1122
  recentFavourites: {
1123
- title: 'Recently added to my favourites',
1123
+ title: 'Recently added to my folders',
1124
1124
  link: 'View all of your folders'
1125
1125
  },
1126
1126
  recentArenaPosts: {
@@ -1031,7 +1031,7 @@ const messages = {
1031
1031
  markAll: 'Merk alle som lest',
1032
1032
  subscribe: 'Du får nå varsling om nye svar på dette innlegget',
1033
1033
  unsubscribe: 'Du har skrudd av varsling om nye svar på dette innlegget',
1034
- commentedOn: 'svarte på innlegget <i>{{title}}</i> som du følger'
1034
+ commentedOn: 'svarte på innlegget <i>{{title}}</i>'
1035
1035
  },
1036
1036
  topicsBy: 'Innlegg av'
1037
1037
  },
@@ -1118,8 +1118,8 @@ const messages = {
1118
1118
  term3: 'NDLA forbeholder seg retten til å oppdatere eller slette utdaterte ressurser.'
1119
1119
  },
1120
1120
  recentFavourites: {
1121
- title: 'Nylig lagt til i mine favoritter',
1122
- link: 'Se alle mappene dine'
1121
+ title: 'Nylig lagt til i mine mapper',
1122
+ link: 'Vuartesjh gaajhkide dov maabpide'
1123
1123
  },
1124
1124
  recentArenaPosts: {
1125
1125
  title: 'Nye innlegg i arenaen',
@@ -1031,7 +1031,7 @@ const messages = {
1031
1031
  markAll: 'Merk alle som lest',
1032
1032
  subscribe: 'Du får no varsling om nye svar på dette innlegget',
1033
1033
  unsubscribe: 'Du har skrudd av varsling om nye svar på dette innlegget',
1034
- commentedOn: 'svarte på innlegget <i>{{title}}</i> som du følger'
1034
+ commentedOn: 'svarte på innlegget <i>{{title}}</i>'
1035
1035
  },
1036
1036
  topicsBy: 'Innlegg av'
1037
1037
  },
@@ -1118,7 +1118,7 @@ const messages = {
1118
1118
  term3: 'NDLA tek atterhald om retten til å oppdatere eller slette utdaterte ressursar.'
1119
1119
  },
1120
1120
  recentFavourites: {
1121
- title: 'Nyleg lagt til i mine favorittar',
1121
+ title: 'Nyleg lagt til i mappene mine',
1122
1122
  link: 'Sjå alle mappene dine'
1123
1123
  },
1124
1124
  recentArenaPosts: {
@@ -1031,7 +1031,7 @@ const messages = {
1031
1031
  markAll: 'Merke visot lohkon',
1032
1032
  subscribe: 'Don oaččut dál dieđu ođđa vástádusaid dán čállosii',
1033
1033
  unsubscribe: 'Don leat heaitán muittuheames ođđa vástádusaid dán čállosii',
1034
- commentedOn: 'vástidii sáhkavuoru <i>{{title}}</i> maid don čuovvut'
1034
+ commentedOn: 'vástidii sáhkavuoru <i>{{title}}</i>'
1035
1035
  },
1036
1036
  topicsBy: 'Sáhkavuorru maid'
1037
1037
  },
@@ -1118,7 +1118,7 @@ const messages = {
1118
1118
  term3: 'NDLA bisuha rievtti ođasmahttit dahje sihkkut boarásmuvvan resurssaid.'
1119
1119
  },
1120
1120
  recentFavourites: {
1121
- title: 'Easka lasihuvvon favorihtaide',
1121
+ title: 'Easka lasihuvvon mu máhpaide',
1122
1122
  link: 'Čájet buot máhpaid'
1123
1123
  },
1124
1124
  recentArenaPosts: {