@ndla/ui 33.3.2 → 33.4.0

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.
@@ -42,39 +42,35 @@ var listElementActiveColor = function listElementActiveColor(contentType) {
42
42
  };
43
43
  var fadeInAdditionalsKeyframe = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\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"])));
44
44
  var ListElement = /*#__PURE__*/_styled("li", {
45
- target: "ehgdkrx6",
45
+ target: "ehgdkrx5",
46
46
  label: "ListElement"
47
47
  })("border:1px solid #d1d6db;border-radius:5px;background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding-right:1rem;", function (props) {
48
- return props.additional && /*#__PURE__*/css("border-style:dashed;animation-name:", fadeInAdditionalsKeyframe, ";animation-duration:0.8s;animation-fill-mode:forwards;;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAgFO","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
48
+ return props.additional && /*#__PURE__*/css("border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAgFO","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
49
49
  }, " ", function (props) {
50
50
  return props.extraBottomMargin && "margin-bottom: ".concat(spacing.large, ";");
51
51
  }, " *{transition:height ease-out 0.2s,width ease-out 0.2s;}", function (props) {
52
52
  return props.active && /*#__PURE__*/css("&:before{", mq.range({
53
53
  from: breakpoints.tablet
54
- }), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(calc(-", spacing.normal, " - ", spacing.small, "));background-color:", listElementActiveColor(props.contentType), ";}};label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA6FO","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
54
+ }), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(calc(-", spacing.normal, " - ", spacing.small, "));background-color:", listElementActiveColor(props.contentType), ";}};label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA6FO","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
55
55
  }, " ", function (_ref) {
56
56
  var hidden = _ref.hidden;
57
57
  return hidden && "display:none; opacity:0;";
58
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoE+C","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
59
- var LinkStyle = /*#__PURE__*/css("display:flex;color:", colors.brand.dark, ";align-items:center;width:auto;padding:", spacing.small, ";box-shadow:none;min-height:70px;;label:LinkStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA8GqB","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
58
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoE+C","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
59
+ var LinkStyle = /*#__PURE__*/css("display:flex;color:", colors.brand.dark, ";align-items:center;width:auto;padding:", spacing.small, ";box-shadow:none;min-height:70px;;label:LinkStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA8GqB","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
60
60
  var ActiveWrapper = /*#__PURE__*/_styled("div", {
61
- target: "ehgdkrx5",
61
+ target: "ehgdkrx4",
62
62
  label: "ActiveWrapper"
63
- })(LinkStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwHgC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
63
+ })(LinkStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwHgC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
64
64
  var ResourceLink = /*#__PURE__*/_styled(SafeLink, {
65
- target: "ehgdkrx4",
66
- label: "ResourceLink"
67
- })(LinkStyle, " &:hover .c-content-type-badge{width:38px;height:38px;svg{width:20px;height:20px;}&.c-content-type-badge--subject-material,&.c-content-type-badge--learning-path,&.c-content-type-badge--source-material,&.c-content-type-badge--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":"AA2HqC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
68
- var Heading = /*#__PURE__*/_styled("h2", {
69
65
  target: "ehgdkrx3",
70
- label: "Heading"
71
- })("font-weight:", fonts.weight.semibold, ";transform:translateY(-1px);text-transform:none;letter-spacing:0;margin:0;display:inline;", fonts.sizes('16px', '26px'), ";", mq.range({
66
+ label: "ResourceLink"
67
+ })(LinkStyle, " &:hover .c-content-type-badge{width:38px;height:38px;svg{width:20px;height:20px;}&.c-content-type-badge--subject-material,&.c-content-type-badge--learning-path,&.c-content-type-badge--source-material,&.c-content-type-badge--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":"AA2HqC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
68
+ var headingStyle = /*#__PURE__*/css("font-weight:", fonts.weight.semibold, ";transform:translateY(-1px);text-transform:none;letter-spacing:0;margin:0;display:inline;", fonts.sizes('16px', '26px'), ";", mq.range({
72
69
  from: breakpoints.tablet
73
70
  }), "{", fonts.sizes('18px', '26px'), ";}", mq.range({
74
71
  from: breakpoints.desktop
75
- }), "{", fonts.sizes('20px', '26px'), ";}span{box-shadow:", colors.link, ";}", ResourceLink, ":hover &,", ResourceLink, ":focus &{span{box-shadow:", colors.linkHover, ";}}", function (props) {
76
- return props.active && /*#__PURE__*/css("color:", colors.brand.greyDark, ";span{box-shadow:none;}small{padding-left:", spacing.small, ";font-weight:", fonts.weight.normal, ";};label:Heading;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+KO","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
77
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoJsC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
72
+ }), "{", fonts.sizes('20px', '26px'), ";}box-shadow:", colors.link, ";", ResourceLink, ":hover &,", ResourceLink, ":focus &{box-shadow:", colors.linkHover, ";};label:headingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiJwB","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
73
+ var activeHeadingStyle = /*#__PURE__*/css("color:", colors.brand.greyDark, ";box-shadow:none;small{padding-left:", spacing.small, ";font-weight:", fonts.weight.normal, ";};label:activeHeadingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwK8B","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
78
74
  var IconWrapper = /*#__PURE__*/_styled("div", {
79
75
  target: "ehgdkrx2",
80
76
  label: "IconWrapper"
@@ -82,15 +78,15 @@ var IconWrapper = /*#__PURE__*/_styled("div", {
82
78
  from: breakpoints.tablet
83
79
  }), "{padding-right:", spacing.small, ";padding-left:", spacing.xsmall, ";}", mq.range({
84
80
  from: breakpoints.desktop
85
- }), "{padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA2L8B","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
81
+ }), "{padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiL8B","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
86
82
  var TypeWrapper = /*#__PURE__*/_styled("div", {
87
83
  target: "ehgdkrx1",
88
84
  label: "TypeWrapper"
89
- })("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA8M8B","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
85
+ })("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoM8B","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
90
86
  var ContentTypeName = /*#__PURE__*/_styled("span", {
91
87
  target: "ehgdkrx0",
92
88
  label: "ContentTypeName"
93
- })("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", 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":"AAoNmC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Additional\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <Core\n                  className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                  aria-label={contentTypeDescription}\n                />\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
89
+ })("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", 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":"AA0MmC","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
94
90
  var ResourceItem = function ResourceItem(_ref2) {
95
91
  var id = _ref2.id,
96
92
  contentTypeName = _ref2.contentTypeName,
@@ -108,6 +104,7 @@ var ResourceItem = function ResourceItem(_ref2) {
108
104
  t = _useTranslation.t;
109
105
  var hidden = additional ? !showAdditionalResources : false;
110
106
  return _jsxs(ListElement, {
107
+ "aria-current": active ? 'page' : undefined,
111
108
  contentType: contentType,
112
109
  hidden: hidden && !active,
113
110
  active: active,
@@ -120,13 +117,11 @@ var ResourceItem = function ResourceItem(_ref2) {
120
117
  background: true,
121
118
  border: false
122
119
  })
123
- }), _jsx(Heading, {
124
- active: true,
125
- children: _jsxs("span", {
126
- children: [name, _jsx("small", {
127
- children: t('resource.youAreHere')
128
- })]
129
- })
120
+ }), _jsxs("span", {
121
+ css: [headingStyle, activeHeadingStyle, ";label:ResourceItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA0PgB","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 React, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\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\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\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(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\nconst headingStyle = css`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\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\n  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst IconWrapper = 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\ntype Props = {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */")],
122
+ children: [name, _jsx("small", {
123
+ children: t('resource.youAreHere')
124
+ })]
130
125
  })]
131
126
  }) : _jsxs(ResourceLink, {
132
127
  to: path,
@@ -136,10 +131,9 @@ var ResourceItem = function ResourceItem(_ref2) {
136
131
  background: true,
137
132
  border: false
138
133
  })
139
- }), _jsx(Heading, {
140
- children: _jsx("span", {
141
- children: name
142
- })
134
+ }), _jsx("span", {
135
+ css: headingStyle,
136
+ children: name
143
137
  })]
144
138
  }), _jsxs(TypeWrapper, {
145
139
  children: [contentTypeName && _jsx(ContentTypeName, {
@@ -153,15 +147,19 @@ var ResourceItem = function ResourceItem(_ref2) {
153
147
  }), showAdditionalResources && contentTypeDescription && _jsxs(_Fragment, {
154
148
  children: [additional && _jsx(Tooltip, {
155
149
  tooltip: contentTypeDescription,
156
- children: _jsx(Additional, {
157
- className: "c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons",
158
- "aria-label": contentTypeDescription
150
+ children: _jsx("div", {
151
+ children: _jsx(Additional, {
152
+ className: "c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons",
153
+ "aria-label": contentTypeDescription
154
+ })
159
155
  })
160
156
  }), !additional && _jsx(Tooltip, {
161
157
  tooltip: contentTypeDescription,
162
- children: _jsx(Core, {
163
- className: "c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons",
164
- "aria-label": contentTypeDescription
158
+ children: _jsx("div", {
159
+ children: _jsx(Core, {
160
+ className: "c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons",
161
+ "aria-label": contentTypeDescription
162
+ })
165
163
  })
166
164
  })]
167
165
  }), heartButton === null || heartButton === void 0 ? void 0 : heartButton(path)]