@ndla/ui 44.0.20 → 44.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/es/Article/Article.js +3 -3
  2. package/es/Footer/FooterPrivacy.js +27 -14
  3. package/es/LearningPaths/LearningPathSticky.js +7 -3
  4. package/es/Masthead/MastheadSearchModal.js +4 -2
  5. package/es/ProgrammeCard/ProgrammeCard.js +3 -5
  6. package/es/ResourceGroup/ResourceItem.js +50 -63
  7. package/es/ResourceGroup/ResourceList.js +11 -19
  8. package/es/locale/messages-en.js +2 -2
  9. package/es/locale/messages-nb.js +2 -2
  10. package/es/locale/messages-nn.js +2 -2
  11. package/es/locale/messages-se.js +2 -2
  12. package/es/locale/messages-sma.js +2 -2
  13. package/lib/Article/Article.js +3 -3
  14. package/lib/Footer/FooterPrivacy.js +32 -21
  15. package/lib/LearningPaths/LearningPathSticky.js +7 -3
  16. package/lib/Masthead/MastheadSearchModal.js +4 -2
  17. package/lib/ProgrammeCard/ProgrammeCard.js +3 -5
  18. package/lib/ResourceGroup/ResourceItem.d.ts +1 -1
  19. package/lib/ResourceGroup/ResourceItem.js +50 -63
  20. package/lib/ResourceGroup/ResourceList.js +11 -19
  21. package/lib/locale/messages-en.js +2 -2
  22. package/lib/locale/messages-nb.js +2 -2
  23. package/lib/locale/messages-nn.js +2 -2
  24. package/lib/locale/messages-se.js +2 -2
  25. package/lib/locale/messages-sma.js +2 -2
  26. package/package.json +7 -7
  27. package/src/Article/Article.tsx +0 -1
  28. package/src/Footer/FooterPrivacy.tsx +21 -30
  29. package/src/LearningPaths/LearningPathSticky.tsx +17 -9
  30. package/src/Masthead/MastheadSearchModal.tsx +6 -1
  31. package/src/ProgrammeCard/ProgrammeCard.tsx +0 -7
  32. package/src/ResourceGroup/ResourceItem.tsx +45 -61
  33. package/src/ResourceGroup/ResourceList.tsx +2 -24
  34. package/src/locale/messages-en.ts +2 -2
  35. package/src/locale/messages-nb.ts +2 -2
  36. package/src/locale/messages-nn.ts +2 -2
  37. package/src/locale/messages-se.ts +2 -2
  38. package/src/locale/messages-sma.ts +2 -2
@@ -6,12 +6,12 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = void 0;
8
8
  var _base = _interopRequireDefault(require("@emotion/styled/base"));
9
+ var _react = require("react");
9
10
  var _reactI18next = require("react-i18next");
10
- var _react = require("@emotion/react");
11
+ var _react2 = require("@emotion/react");
11
12
  var _safelink = _interopRequireDefault(require("@ndla/safelink"));
12
13
  var _common = require("@ndla/icons/common");
13
14
  var _core = require("@ndla/core");
14
- var _tooltip = _interopRequireDefault(require("@ndla/tooltip"));
15
15
  var _ContentTypeBadge = _interopRequireDefault(require("../ContentTypeBadge"));
16
16
  var contentTypes = _interopRequireWildcard(require("../model/ContentType"));
17
17
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
@@ -46,22 +46,13 @@ var listElementActiveColor = function listElementActiveColor(contentType) {
46
46
  }
47
47
  return 'none';
48
48
  };
49
- var fadeInAdditionalsKeyframe = (0, _react.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"])));
49
+ var fadeInAdditionalsKeyframe = (0, _react2.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"])));
50
50
  var ListElement = /*#__PURE__*/(0, _base.default)("li", {
51
51
  target: "ehgdkrx8",
52
52
  label: "ListElement"
53
- })("border:1px solid #d1d6db;border-radius:5px;background:", _core.colors.white, ";margin-bottom:", _core.spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", _core.spacing.small, ";", function (props) {
54
- return props.additional && /*#__PURE__*/(0, _react.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":"AAiFO","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
55
- }, " ", function (props) {
56
- return props.extraBottomMargin && "margin-bottom: ".concat(_core.spacing.large, ";");
57
- }, " *{transition:height ease-out 0.2s,width ease-out 0.2s;}", function (props) {
58
- return props.active && /*#__PURE__*/(0, _react.css)("&:before{", _core.mq.range({
59
- from: _core.breakpoints.tablet
60
- }), "{content:'';display:block;position:absolute;width:", _core.spacing.small, ";height:", _core.spacing.small, ";border-radius:100%;transform:translate(calc(-", _core.spacing.normal, " - ", _core.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":"AA8FO","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
61
- }, " ", function (_ref) {
62
- var hidden = _ref.hidden;
63
- return hidden && "display:none; opacity:0;";
64
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqE+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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
53
+ })("border:1px solid ", _core.colors.brand.neutral7, ";border-radius:", _core.misc.borderRadius, ";background:", _core.colors.white, ";margin-bottom:", _core.spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", _core.spacing.small, ";&[data-additional='true']{border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";}*{transition:height ease-out 0.2s,width ease-out 0.2s;}&[data-active='true']{&:before{", _core.mq.range({
54
+ from: _core.breakpoints.tablet
55
+ }), "{content:'';display:block;position:absolute;width:", _core.spacing.small, ";height:", _core.spacing.small, ";border-radius:100%;transform:translate(-", _core.spacing.mediumlarge, ");background-color:var(--contentTypeBg);}}}&[hidden]{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4D6B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
65
56
  var ResourceLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
66
57
  target: "ehgdkrx7",
67
58
  label: "ResourceLink"
@@ -69,7 +60,7 @@ var ResourceLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
69
60
  from: _core.breakpoints.tablet
70
61
  }), "{", _core.fonts.sizes('18px', '26px'), ";}", _core.mq.range({
71
62
  from: _core.breakpoints.desktop
72
- }), "{", _core.fonts.sizes('20px', '26px'), ";}&:hover{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+GqC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
63
+ }), "{", _core.fonts.sizes('20px', '26px'), ";}&:hover{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkGqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
73
64
  var ContentBadgeWrapper = /*#__PURE__*/(0, _base.default)("div", {
74
65
  target: "ehgdkrx6",
75
66
  label: "ContentBadgeWrapper"
@@ -77,15 +68,15 @@ var ContentBadgeWrapper = /*#__PURE__*/(0, _base.default)("div", {
77
68
  from: _core.breakpoints.tablet
78
69
  }), "{padding-right:", _core.spacing.small, ";padding-left:", _core.spacing.xsmall, ";}", _core.mq.range({
79
70
  from: _core.breakpoints.desktop
80
- }), "{padding-right:", _core.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiIsC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
71
+ }), "{padding-right:", _core.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoHsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
81
72
  var TypeWrapper = /*#__PURE__*/(0, _base.default)("div", {
82
73
  target: "ehgdkrx5",
83
74
  label: "TypeWrapper"
84
- })("display:flex;align-items:center;gap:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoJ8B","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
75
+ })("display:flex;align-items:center;gap:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAuI8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
85
76
  var ContentTypeName = /*#__PURE__*/(0, _base.default)("span", {
86
77
  target: "ehgdkrx4",
87
78
  label: "ContentTypeName"
88
- })("font-family:", _core.fonts.sans, ";", _core.fonts.sizes('14px', '18px'), ";font-weight:", _core.fonts.weight.semibold, ";color:", _core.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA0JmC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
79
+ })("font-family:", _core.fonts.sans, ";", _core.fonts.sizes('14px', '18px'), ";font-weight:", _core.fonts.weight.semibold, ";color:", _core.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA6ImC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
89
80
  var InlineContainer = /*#__PURE__*/(0, _base.default)("div", {
90
81
  target: "ehgdkrx3",
91
82
  label: "InlineContainer"
@@ -95,17 +86,17 @@ var InlineContainer = /*#__PURE__*/(0, _base.default)("div", {
95
86
  } : {
96
87
  name: "1u4hpl4",
97
88
  styles: "display:inline",
98
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkKkC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
89
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqJkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
99
90
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
100
91
  });
101
92
  var ResourceWrapper = /*#__PURE__*/(0, _base.default)("div", {
102
93
  target: "ehgdkrx2",
103
94
  label: "ResourceWrapper"
104
- })("display:flex;gap:", _core.spacing.xsmall, ";align-items:center;: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":"AAsKkC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
95
+ })("display:flex;gap:", _core.spacing.xsmall, ";align-items:center;: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":"AAyJkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
105
96
  var CurrentSmall = /*#__PURE__*/(0, _base.default)("small", {
106
97
  target: "ehgdkrx1",
107
98
  label: "CurrentSmall"
108
- })("margin-left:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAgMiC","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
99
+ })("margin-left:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAmLiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
109
100
  var IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
110
101
  target: "ehgdkrx0",
111
102
  label: "IconWrapper"
@@ -115,22 +106,21 @@ var IconWrapper = /*#__PURE__*/(0, _base.default)("div", {
115
106
  } : {
116
107
  name: "ji2k1n",
117
108
  styles: "display:flex;flex-grow:1;svg{width:26px;height:26px;}",
118
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+M8B","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 { 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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  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    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
109
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkM8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\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\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional='true'] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  &[data-active='true'] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: '';\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return { '--contentTypeBg': listElementActiveColor(contentType) } as unknown as CSSProperties;\n  }, [contentType]);\n\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      hidden={hidden && !active}\n      data-active={active}\n      data-additional={additional}\n      style={listElementVars}\n    >\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <IconWrapper aria-label={t('article.access.onlyTeacher')} title={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
119
110
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
120
111
  });
121
- var ResourceItem = function ResourceItem(_ref2) {
122
- var id = _ref2.id,
123
- contentTypeName = _ref2.contentTypeName,
124
- contentTypeDescription = _ref2.contentTypeDescription,
125
- name = _ref2.name,
126
- path = _ref2.path,
127
- contentType = _ref2.contentType,
128
- active = _ref2.active,
129
- additional = _ref2.additional,
130
- extraBottomMargin = _ref2.extraBottomMargin,
131
- showAdditionalResources = _ref2.showAdditionalResources,
132
- access = _ref2.access,
133
- heartButton = _ref2.heartButton;
112
+ var ResourceItem = function ResourceItem(_ref) {
113
+ var id = _ref.id,
114
+ contentTypeName = _ref.contentTypeName,
115
+ contentTypeDescription = _ref.contentTypeDescription,
116
+ name = _ref.name,
117
+ path = _ref.path,
118
+ contentType = _ref.contentType,
119
+ active = _ref.active,
120
+ additional = _ref.additional,
121
+ showAdditionalResources = _ref.showAdditionalResources,
122
+ access = _ref.access,
123
+ heartButton = _ref.heartButton;
134
124
  var _useTranslation = (0, _reactI18next.useTranslation)(),
135
125
  t = _useTranslation.t;
136
126
  var accessId = "".concat(id, "-teacher");
@@ -138,13 +128,18 @@ var ResourceItem = function ResourceItem(_ref2) {
138
128
  var additionalId = "".concat(id, "-additional");
139
129
  var describedBy = "".concat(coreId, " ").concat(additionalId, " ").concat(accessId);
140
130
  var hidden = additional ? !showAdditionalResources : false;
131
+ var listElementVars = (0, _react.useMemo)(function () {
132
+ if (!contentType) return {};
133
+ return {
134
+ '--contentTypeBg': listElementActiveColor(contentType)
135
+ };
136
+ }, [contentType]);
141
137
  return (0, _jsxRuntime.jsxs)(ListElement, {
142
138
  "aria-current": active ? 'page' : undefined,
143
- contentType: contentType,
144
139
  hidden: hidden && !active,
145
- active: active,
146
- additional: additional,
147
- extraBottomMargin: extraBottomMargin,
140
+ "data-active": active,
141
+ "data-additional": additional,
142
+ style: listElementVars,
148
143
  children: [(0, _jsxRuntime.jsxs)(ResourceWrapper, {
149
144
  children: [(0, _jsxRuntime.jsx)(ContentBadgeWrapper, {
150
145
  children: (0, _jsxRuntime.jsx)(_ContentTypeBadge.default, {
@@ -165,31 +160,23 @@ var ResourceItem = function ResourceItem(_ref2) {
165
160
  }), (0, _jsxRuntime.jsxs)(TypeWrapper, {
166
161
  children: [contentTypeName && (0, _jsxRuntime.jsx)(ContentTypeName, {
167
162
  children: contentTypeName
168
- }), access && access === 'teacher' && (0, _jsxRuntime.jsx)(_tooltip.default, {
169
- tooltip: t('article.access.onlyTeacher'),
170
- children: (0, _jsxRuntime.jsx)(IconWrapper, {
171
- children: (0, _jsxRuntime.jsx)(_common.HumanMaleBoard, {
172
- id: accessId,
173
- "aria-label": t('article.access.onlyTeacher')
174
- })
163
+ }), access && access === 'teacher' && (0, _jsxRuntime.jsx)(IconWrapper, {
164
+ "aria-label": t('article.access.onlyTeacher'),
165
+ title: t('article.access.onlyTeacher'),
166
+ children: (0, _jsxRuntime.jsx)(_common.HumanMaleBoard, {
167
+ id: accessId
175
168
  })
176
169
  }), showAdditionalResources && contentTypeDescription && (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
177
- children: [additional && (0, _jsxRuntime.jsx)(_tooltip.default, {
178
- tooltip: contentTypeDescription,
179
- children: (0, _jsxRuntime.jsx)(IconWrapper, {
180
- children: (0, _jsxRuntime.jsx)(_common.Additional, {
181
- id: additionalId,
182
- "aria-label": contentTypeDescription
183
- })
184
- })
185
- }), !additional && (0, _jsxRuntime.jsx)(_tooltip.default, {
186
- tooltip: contentTypeDescription,
187
- children: (0, _jsxRuntime.jsx)(IconWrapper, {
188
- children: (0, _jsxRuntime.jsx)(_common.Core, {
189
- id: coreId,
190
- "aria-label": contentTypeDescription
191
- })
192
- })
170
+ children: [additional && (0, _jsxRuntime.jsx)(IconWrapper, {
171
+ id: additionalId,
172
+ "aria-label": contentTypeDescription,
173
+ title: contentTypeDescription,
174
+ children: (0, _jsxRuntime.jsx)(_common.Additional, {})
175
+ }), !additional && (0, _jsxRuntime.jsx)(IconWrapper, {
176
+ id: coreId,
177
+ "aria-label": contentTypeDescription,
178
+ title: contentTypeDescription,
179
+ children: (0, _jsxRuntime.jsx)(_common.Core, {})
193
180
  })]
194
181
  }), heartButton === null || heartButton === void 0 ? void 0 : heartButton(path)]
195
182
  })]