@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
@@ -10,12 +10,12 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
10
10
  *
11
11
  */
12
12
 
13
+ import { useMemo } from 'react';
13
14
  import { useTranslation } from 'react-i18next';
14
- import { css, keyframes } from '@emotion/react';
15
+ import { keyframes } from '@emotion/react';
15
16
  import SafeLink from '@ndla/safelink';
16
17
  import { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';
17
- import { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
18
- import Tooltip from '@ndla/tooltip';
18
+ import { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';
19
19
  import ContentTypeBadge from '../ContentTypeBadge';
20
20
  import * as contentTypes from '../model/ContentType';
21
21
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
@@ -44,18 +44,9 @@ var fadeInAdditionalsKeyframe = keyframes(_templateObject || (_templateObject =
44
44
  var ListElement = /*#__PURE__*/_styled("li", {
45
45
  target: "ehgdkrx8",
46
46
  label: "ListElement"
47
- })("border:1px solid #d1d6db;border-radius:5px;background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", spacing.small, ";", function (props) {
48
- return props.additional && /*#__PURE__*/css("border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
49
- }, " ", function (props) {
50
- return props.extraBottomMargin && "margin-bottom: ".concat(spacing.large, ";");
51
- }, " *{transition:height ease-out 0.2s,width ease-out 0.2s;}", function (props) {
52
- return props.active && /*#__PURE__*/css("&:before{", mq.range({
53
- from: breakpoints.tablet
54
- }), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(calc(-", spacing.normal, " - ", spacing.small, "));background-color:", listElementActiveColor(props.contentType), ";}};label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
55
- }, " ", function (_ref) {
56
- var hidden = _ref.hidden;
57
- return hidden && "display:none; opacity:0;";
58
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
47
+ })("border:1px solid ", colors.brand.neutral7, ";border-radius:", misc.borderRadius, ";background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", 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{", mq.range({
48
+ from: breakpoints.tablet
49
+ }), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(-", 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"]} */"));
59
50
  var ResourceLink = /*#__PURE__*/_styled(SafeLink, {
60
51
  target: "ehgdkrx7",
61
52
  label: "ResourceLink"
@@ -63,7 +54,7 @@ var ResourceLink = /*#__PURE__*/_styled(SafeLink, {
63
54
  from: breakpoints.tablet
64
55
  }), "{", fonts.sizes('18px', '26px'), ";}", mq.range({
65
56
  from: breakpoints.desktop
66
- }), "{", 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"]} */"));
57
+ }), "{", 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"]} */"));
67
58
  var ContentBadgeWrapper = /*#__PURE__*/_styled("div", {
68
59
  target: "ehgdkrx6",
69
60
  label: "ContentBadgeWrapper"
@@ -71,15 +62,15 @@ var ContentBadgeWrapper = /*#__PURE__*/_styled("div", {
71
62
  from: breakpoints.tablet
72
63
  }), "{padding-right:", spacing.small, ";padding-left:", spacing.xsmall, ";}", mq.range({
73
64
  from: breakpoints.desktop
74
- }), "{padding-right:", 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"]} */"));
65
+ }), "{padding-right:", 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"]} */"));
75
66
  var TypeWrapper = /*#__PURE__*/_styled("div", {
76
67
  target: "ehgdkrx5",
77
68
  label: "TypeWrapper"
78
- })("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
69
+ })("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
79
70
  var ContentTypeName = /*#__PURE__*/_styled("span", {
80
71
  target: "ehgdkrx4",
81
72
  label: "ContentTypeName"
82
- })("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
73
+ })("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"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"]} */"));
83
74
  var InlineContainer = /*#__PURE__*/_styled("div", {
84
75
  target: "ehgdkrx3",
85
76
  label: "InlineContainer"
@@ -89,17 +80,17 @@ var InlineContainer = /*#__PURE__*/_styled("div", {
89
80
  } : {
90
81
  name: "1u4hpl4",
91
82
  styles: "display:inline",
92
- 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"]} */",
83
+ 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"]} */",
93
84
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
94
85
  });
95
86
  var ResourceWrapper = /*#__PURE__*/_styled("div", {
96
87
  target: "ehgdkrx2",
97
88
  label: "ResourceWrapper"
98
- })("display:flex;gap:", 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"]} */"));
89
+ })("display:flex;gap:", 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"]} */"));
99
90
  var CurrentSmall = /*#__PURE__*/_styled("small", {
100
91
  target: "ehgdkrx1",
101
92
  label: "CurrentSmall"
102
- })("margin-left:", 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"]} */"));
93
+ })("margin-left:", 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"]} */"));
103
94
  var IconWrapper = /*#__PURE__*/_styled("div", {
104
95
  target: "ehgdkrx0",
105
96
  label: "IconWrapper"
@@ -109,22 +100,21 @@ var IconWrapper = /*#__PURE__*/_styled("div", {
109
100
  } : {
110
101
  name: "ji2k1n",
111
102
  styles: "display:flex;flex-grow:1;svg{width:26px;height:26px;}",
112
- 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"]} */",
103
+ 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"]} */",
113
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
114
105
  });
115
- var ResourceItem = function ResourceItem(_ref2) {
116
- var id = _ref2.id,
117
- contentTypeName = _ref2.contentTypeName,
118
- contentTypeDescription = _ref2.contentTypeDescription,
119
- name = _ref2.name,
120
- path = _ref2.path,
121
- contentType = _ref2.contentType,
122
- active = _ref2.active,
123
- additional = _ref2.additional,
124
- extraBottomMargin = _ref2.extraBottomMargin,
125
- showAdditionalResources = _ref2.showAdditionalResources,
126
- access = _ref2.access,
127
- heartButton = _ref2.heartButton;
106
+ var ResourceItem = function ResourceItem(_ref) {
107
+ var id = _ref.id,
108
+ contentTypeName = _ref.contentTypeName,
109
+ contentTypeDescription = _ref.contentTypeDescription,
110
+ name = _ref.name,
111
+ path = _ref.path,
112
+ contentType = _ref.contentType,
113
+ active = _ref.active,
114
+ additional = _ref.additional,
115
+ showAdditionalResources = _ref.showAdditionalResources,
116
+ access = _ref.access,
117
+ heartButton = _ref.heartButton;
128
118
  var _useTranslation = useTranslation(),
129
119
  t = _useTranslation.t;
130
120
  var accessId = "".concat(id, "-teacher");
@@ -132,13 +122,18 @@ var ResourceItem = function ResourceItem(_ref2) {
132
122
  var additionalId = "".concat(id, "-additional");
133
123
  var describedBy = "".concat(coreId, " ").concat(additionalId, " ").concat(accessId);
134
124
  var hidden = additional ? !showAdditionalResources : false;
125
+ var listElementVars = useMemo(function () {
126
+ if (!contentType) return {};
127
+ return {
128
+ '--contentTypeBg': listElementActiveColor(contentType)
129
+ };
130
+ }, [contentType]);
135
131
  return _jsxs(ListElement, {
136
132
  "aria-current": active ? 'page' : undefined,
137
- contentType: contentType,
138
133
  hidden: hidden && !active,
139
- active: active,
140
- additional: additional,
141
- extraBottomMargin: extraBottomMargin,
134
+ "data-active": active,
135
+ "data-additional": additional,
136
+ style: listElementVars,
142
137
  children: [_jsxs(ResourceWrapper, {
143
138
  children: [_jsx(ContentBadgeWrapper, {
144
139
  children: _jsx(ContentTypeBadge, {
@@ -159,31 +154,23 @@ var ResourceItem = function ResourceItem(_ref2) {
159
154
  }), _jsxs(TypeWrapper, {
160
155
  children: [contentTypeName && _jsx(ContentTypeName, {
161
156
  children: contentTypeName
162
- }), access && access === 'teacher' && _jsx(Tooltip, {
163
- tooltip: t('article.access.onlyTeacher'),
164
- children: _jsx(IconWrapper, {
165
- children: _jsx(HumanMaleBoard, {
166
- id: accessId,
167
- "aria-label": t('article.access.onlyTeacher')
168
- })
157
+ }), access && access === 'teacher' && _jsx(IconWrapper, {
158
+ "aria-label": t('article.access.onlyTeacher'),
159
+ title: t('article.access.onlyTeacher'),
160
+ children: _jsx(HumanMaleBoard, {
161
+ id: accessId
169
162
  })
170
163
  }), showAdditionalResources && contentTypeDescription && _jsxs(_Fragment, {
171
- children: [additional && _jsx(Tooltip, {
172
- tooltip: contentTypeDescription,
173
- children: _jsx(IconWrapper, {
174
- children: _jsx(Additional, {
175
- id: additionalId,
176
- "aria-label": contentTypeDescription
177
- })
178
- })
179
- }), !additional && _jsx(Tooltip, {
180
- tooltip: contentTypeDescription,
181
- children: _jsx(IconWrapper, {
182
- children: _jsx(Core, {
183
- id: coreId,
184
- "aria-label": contentTypeDescription
185
- })
186
- })
164
+ children: [additional && _jsx(IconWrapper, {
165
+ id: additionalId,
166
+ "aria-label": contentTypeDescription,
167
+ title: contentTypeDescription,
168
+ children: _jsx(Additional, {})
169
+ }), !additional && _jsx(IconWrapper, {
170
+ id: coreId,
171
+ "aria-label": contentTypeDescription,
172
+ title: contentTypeDescription,
173
+ children: _jsx(Core, {})
187
174
  })]
188
175
  }), heartButton === null || heartButton === void 0 ? void 0 : heartButton(path)]
189
176
  })]