@ndla/ui 50.10.2 → 50.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/es/AudioPlayer/SpeechControl.js +4 -3
  2. package/es/ContentTypeBadge/ContentTypeBadge.js +21 -21
  3. package/es/ContentTypeBadge/index.js +1 -1
  4. package/es/Embed/ConceptEmbed.js +7 -7
  5. package/es/Embed/RelatedContentEmbed.js +1 -1
  6. package/es/Footer/Footer.js +35 -71
  7. package/es/Footer/FooterLinks.js +65 -52
  8. package/es/Footer/FooterText.js +2 -4
  9. package/es/Gloss/Gloss.js +10 -9
  10. package/es/Hero/Hero.js +7 -7
  11. package/es/Hero/index.js +1 -1
  12. package/es/LanguageSelector/LanguageSelector.js +6 -6
  13. package/es/RelatedArticleList/RelatedArticleList.js +8 -8
  14. package/es/ResourceGroup/ResourceGroup.js +6 -5
  15. package/es/ResourceGroup/ResourceItem.js +42 -37
  16. package/es/ResourceGroup/ResourceList.js +24 -26
  17. package/es/SearchTypeResult/SearchTypeHeader.js +10 -9
  18. package/es/SearchTypeResult/SearchTypeResult.js +2 -2
  19. package/es/all.css +1 -1
  20. package/es/index.js +2 -2
  21. package/es/locale/messages-en.js +7 -4
  22. package/es/locale/messages-nb.js +7 -4
  23. package/es/locale/messages-nn.js +7 -4
  24. package/es/locale/messages-se.js +6 -3
  25. package/es/locale/messages-sma.js +7 -4
  26. package/es/model/ContentType.js +8 -6
  27. package/es/utils/resourceTypeColor.js +2 -2
  28. package/lib/AudioPlayer/SpeechControl.d.ts +2 -1
  29. package/lib/AudioPlayer/SpeechControl.js +4 -3
  30. package/lib/ContentTypeBadge/ContentTypeBadge.d.ts +1 -1
  31. package/lib/ContentTypeBadge/ContentTypeBadge.js +23 -23
  32. package/lib/ContentTypeBadge/index.d.ts +1 -1
  33. package/lib/ContentTypeBadge/index.js +2 -2
  34. package/lib/Embed/ConceptEmbed.js +7 -7
  35. package/lib/Embed/RelatedContentEmbed.js +1 -1
  36. package/lib/Footer/Footer.d.ts +1 -2
  37. package/lib/Footer/Footer.js +32 -68
  38. package/lib/Footer/FooterLinks.d.ts +5 -1
  39. package/lib/Footer/FooterLinks.js +65 -50
  40. package/lib/Footer/FooterText.js +2 -4
  41. package/lib/Gloss/Gloss.js +10 -9
  42. package/lib/Hero/Hero.d.ts +2 -2
  43. package/lib/Hero/Hero.js +8 -8
  44. package/lib/Hero/index.d.ts +1 -1
  45. package/lib/Hero/index.js +2 -2
  46. package/lib/LanguageSelector/LanguageSelector.js +5 -5
  47. package/lib/RelatedArticleList/RelatedArticleList.js +8 -8
  48. package/lib/ResourceGroup/ResourceGroup.js +6 -5
  49. package/lib/ResourceGroup/ResourceItem.js +42 -37
  50. package/lib/ResourceGroup/ResourceList.js +24 -26
  51. package/lib/SearchTypeResult/SearchTypeHeader.js +10 -9
  52. package/lib/SearchTypeResult/SearchTypeResult.d.ts +1 -1
  53. package/lib/SearchTypeResult/SearchTypeResult.js +2 -2
  54. package/lib/all.css +1 -1
  55. package/lib/index.d.ts +2 -2
  56. package/lib/index.js +12 -12
  57. package/lib/locale/messages-en.d.ts +4 -1
  58. package/lib/locale/messages-en.js +7 -4
  59. package/lib/locale/messages-nb.d.ts +4 -1
  60. package/lib/locale/messages-nb.js +7 -4
  61. package/lib/locale/messages-nn.d.ts +4 -1
  62. package/lib/locale/messages-nn.js +7 -4
  63. package/lib/locale/messages-se.d.ts +4 -1
  64. package/lib/locale/messages-se.js +6 -3
  65. package/lib/locale/messages-sma.d.ts +4 -1
  66. package/lib/locale/messages-sma.js +7 -4
  67. package/lib/model/ContentType.d.ts +5 -3
  68. package/lib/model/ContentType.js +9 -7
  69. package/lib/model/index.d.ts +2 -1
  70. package/lib/utils/resourceTypeColor.js +2 -2
  71. package/package.json +17 -17
  72. package/src/Article/component.article.scss +2 -2
  73. package/src/AudioPlayer/SpeechControl.tsx +4 -3
  74. package/src/ContentTypeBadge/ContentTypeBadge.stories.tsx +2 -2
  75. package/src/ContentTypeBadge/ContentTypeBadge.tsx +15 -19
  76. package/src/ContentTypeBadge/index.ts +1 -1
  77. package/src/Embed/ConceptEmbed.tsx +3 -3
  78. package/src/Embed/RelatedContentEmbed.tsx +1 -1
  79. package/src/Footer/Footer.stories.tsx +4 -13
  80. package/src/Footer/Footer.tsx +46 -117
  81. package/src/Footer/FooterLinks.tsx +73 -65
  82. package/src/Footer/FooterText.tsx +5 -9
  83. package/src/Gloss/Gloss.tsx +7 -6
  84. package/src/Hero/Hero.tsx +8 -10
  85. package/src/Hero/index.ts +1 -1
  86. package/src/LanguageSelector/LanguageSelector.tsx +2 -1
  87. package/src/RelatedArticleList/RelatedArticleList.tsx +1 -1
  88. package/src/ResourceGroup/ResourceGroup.tsx +2 -2
  89. package/src/ResourceGroup/ResourceItem.stories.tsx +2 -2
  90. package/src/ResourceGroup/ResourceItem.tsx +62 -36
  91. package/src/ResourceGroup/ResourceList.tsx +28 -30
  92. package/src/SearchTypeResult/SearchTypeHeader.tsx +8 -1
  93. package/src/SearchTypeResult/SearchTypeResult.tsx +1 -1
  94. package/src/index.ts +2 -2
  95. package/src/locale/messages-en.ts +7 -4
  96. package/src/locale/messages-nb.ts +7 -4
  97. package/src/locale/messages-nn.ts +7 -4
  98. package/src/locale/messages-se.ts +6 -3
  99. package/src/locale/messages-sma.ts +7 -4
  100. package/src/model/ContentType.ts +8 -5
  101. package/src/utils/resourceTypeColor.tsx +2 -2
  102. package/es/Footer/FooterPrivacy.js +0 -60
  103. package/lib/Footer/FooterPrivacy.d.ts +0 -15
  104. package/lib/Footer/FooterPrivacy.js +0 -64
  105. package/src/Footer/FooterPrivacy.tsx +0 -70
@@ -27,8 +27,8 @@ const listElementActiveColor = contentType => {
27
27
  return colors.tasksAndActivities.dark;
28
28
  case contentTypes.ASSESSMENT_RESOURCES:
29
29
  return colors.assessmentResource.dark;
30
- case contentTypes.EXTERNAL_LEARNING_RESOURCES:
31
- return colors.externalLearningResource.dark;
30
+ case contentTypes.CONCEPT:
31
+ return colors.concept.text;
32
32
  case contentTypes.SOURCE_MATERIAL:
33
33
  return colors.sourceMaterial.dark;
34
34
  case contentTypes.LEARNING_PATH:
@@ -61,49 +61,51 @@ const fadeInAdditionalsKeyframe = keyframes`
61
61
  const ListElement = /*#__PURE__*/_styled("li", {
62
62
  target: "ehgdkrx7",
63
63
  label: "ListElement"
64
- })("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({
64
+ })("border:1px solid ", colors.brand.neutral7, ";border-radius:", misc.borderRadius, ";background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:grid;align-items:center;grid-template-areas:\"badge resourceType typeWrapper\" \"badge resourceLink typeWrapper\";grid-row-gap:", spacing.xsmall, ";grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;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({
65
65
  from: breakpoints.tablet
66
- }), "{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 { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
66
+ }), "{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;}[data-badge-wrapper=\"true\"]{&:has(+ a:hover){svg{width:20px;height:20px;}}}&:not([data-content-type]){grid-template-areas:\"badge resourceLink typeWrapper\";grid-row-gap:0;align-items:center;}", mq.range({
67
+ from: breakpoints.desktop
68
+ }), "{grid-template-areas:\"badge resourceLink resourceType typeWrapper\";grid-row-gap:0;align-items:center;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4D6B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
67
69
  const ResourceLink = /*#__PURE__*/_styled(SafeLink, {
68
70
  target: "ehgdkrx6",
69
71
  label: "ResourceLink"
70
- })("display:flex;width:100%;align-items:center;font-weight:", fonts.weight.semibold, ";box-shadow:none;&[data-active=\"false\"]{text-decoration:underline;text-underline-offset:5px;}color:", colors.brand.dark, ";", fonts.sizes("16px", "26px"), ";", mq.range({
72
+ })("grid-area:resourceLink;display:flex;width:100%;align-items:center;font-weight:", fonts.weight.semibold, ";box-shadow:none;&[data-active=\"false\"]{text-decoration:underline;text-underline-offset:5px;}color:", colors.brand.dark, ";", fonts.sizes("16px", "26px"), ";", mq.range({
71
73
  from: breakpoints.tablet
72
74
  }), "{", fonts.sizes("18px", "26px"), ";}", mq.range({
73
75
  from: breakpoints.desktop
74
- }), "{", fonts.sizes("20px", "26px"), ";}&:hover{text-decoration:none;[data-badge-wrapper=\"true\"]{[data-badge]{width:", spacing.mediumlarge, ";height:", spacing.mediumlarge, ";svg{width:20px;height:20px;}[data-type=\"subject-material\"],[data-type=\"learning-path\"],[data-type=\"source-material\"],[data-type=\"external-learning-resources\"]{svg{width:", spacing.medium, ";height:", spacing.medium, ";}}}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoGqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
75
- const InlineContainer = /*#__PURE__*/_styled("div", {
76
+ }), "{", 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":"AA4HqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
77
+ const TitleContainer = /*#__PURE__*/_styled("div", {
76
78
  target: "ehgdkrx5",
77
- label: "InlineContainer"
78
- })(process.env.NODE_ENV === "production" ? {
79
- name: "14kk15e",
80
- styles: "display:inline;width:100%"
81
- } : {
82
- name: "14kk15e",
83
- styles: "display:inline;width:100%",
84
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+IkC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
85
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
86
- });
79
+ label: "TitleContainer"
80
+ })("align-items:normal;display:flex;flex-direction:column;", mq.range({
81
+ from: breakpoints.desktop
82
+ }), "{align-items:center;flex-direction:row;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoJiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
87
83
  const ContentBadgeWrapper = /*#__PURE__*/_styled("div", {
88
84
  target: "ehgdkrx4",
89
85
  label: "ContentBadgeWrapper"
90
- })("display:flex;flex:0 0 auto;text-align:center;justify-content:center;align-items:center;width:42px;height:42px;box-sizing:content-box;padding-right:", spacing.small, ";", mq.range({
86
+ })("grid-area:badge;display:flex;flex:0 0 auto;text-align:center;justify-content:center;align-items:center;width:42px;height:42px;box-sizing:content-box;padding-right:", spacing.small, ";", mq.range({
91
87
  from: breakpoints.tablet
92
88
  }), "{padding-right:", spacing.small, ";padding-left:", spacing.xsmall, ";}", mq.range({
93
89
  from: breakpoints.desktop
94
- }), "{padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoJsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
90
+ }), "{align-items:center;padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA8JsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
95
91
  const TypeWrapper = /*#__PURE__*/_styled("div", {
96
92
  target: "ehgdkrx3",
97
93
  label: "TypeWrapper"
98
- })("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":"AAuK8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
94
+ })("grid-area:typeWrapper;display:flex;align-items:center;gap:", spacing.xsmall, ";", mq.range({
95
+ from: breakpoints.desktop
96
+ }), "{align-items:center;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAmL8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
99
97
  const ContentTypeName = /*#__PURE__*/_styled("span", {
100
98
  target: "ehgdkrx2",
101
99
  label: "ContentTypeName"
102
- })("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":"AA6KmC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
100
+ })("grid-area:resourceType;font-family:", fonts.sans, ";", fonts.sizes("14px", "18px"), ";font-weight:", fonts.weight.semibold, ";color:", colors.text.light, ";text-align:left;", mq.range({
101
+ from: breakpoints.desktop
102
+ }), "{padding-left:0;text-align:right;margin:0 ", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA6LmC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
103
103
  const CurrentSmall = /*#__PURE__*/_styled("small", {
104
104
  target: "ehgdkrx1",
105
105
  label: "CurrentSmall"
106
- })("margin-left:", spacing.xsmall, ";text-decoration:none;color:", colors.text.primary, ";font-weight:", fonts.weight.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqLiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
106
+ })("text-decoration:none;color:", colors.text.primary, ";font-weight:", fonts.weight.normal, ";white-space:nowrap;", mq.range({
107
+ from: breakpoints.desktop
108
+ }), "{padding:0 ", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA2MiC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
107
109
  const IconWrapper = /*#__PURE__*/_styled("div", {
108
110
  target: "ehgdkrx0",
109
111
  label: "IconWrapper"
@@ -113,7 +115,7 @@ const IconWrapper = /*#__PURE__*/_styled("div", {
113
115
  } : {
114
116
  name: "5thnkd",
115
117
  styles: "display:flex;flex-grow:1",
116
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwM8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return \"none\";\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\nconst ListElement = styled.li`\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: ${misc.borderRadius};\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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    [data-badge-wrapper=\"true\"] {\n      [data-badge] {\n        width: ${spacing.mediumlarge};\n        height: ${spacing.mediumlarge};\n\n        svg {\n          width: 20px;\n          height: 20px;\n        }\n        [data-type=\"subject-material\"],\n        [data-type=\"learning-path\"],\n        [data-type=\"source-material\"],\n        [data-type=\"external-learning-resources\"] {\n          svg {\n            width: ${spacing.medium};\n            height: ${spacing.medium};\n          }\n        }\n      }\n    }\n  }\n`;\n\nconst InlineContainer = styled.div`\n  display: inline;\n  width: 100%;\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 CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <ContentBadgeWrapper data-badge-wrapper={!active}>\n          <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          {name}\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceLink>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
118
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiO8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { CSSProperties, ReactNode, useMemo } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { keyframes } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing } from \"@ndla/core\";\nimport { Additional, Core, HumanMaleBoard } from \"@ndla/icons/common\";\nimport SafeLink from \"@ndla/safelink\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport * as contentTypes from \"../model/ContentType\";\nimport { Resource } from \"../types\";\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.CONCEPT:\n      return colors.concept.text;\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: grid;\n  align-items: center;\n  grid-template-areas:\n    \"badge resourceType typeWrapper\"\n    \"badge resourceLink typeWrapper\";\n  grid-row-gap: ${spacing.xsmall};\n  grid-template-columns: auto 1fr auto;\n  grid-template-rows: auto auto;\n\n  padding: ${spacing.small};\n  &[data-additional=\"true\"] {\n    border-style: dashed;\n    animation-duration: 0.8s;\n    animation-fill-mode: forwards;\n    animation: ${fadeInAdditionalsKeyframe};\n  }\n\n  * {\n    transition:\n      height ease-out 0.2s,\n      width ease-out 0.2s;\n  }\n  &[data-active=\"true\"] {\n    &:before {\n      ${mq.range({ from: breakpoints.tablet })} {\n        content: \"\";\n        display: block;\n        position: absolute;\n        width: ${spacing.small};\n        height: ${spacing.small};\n        border-radius: 100%;\n        transform: translate(-${spacing.mediumlarge});\n        background-color: var(--contentTypeBg);\n      }\n    }\n  }\n  &[hidden] {\n    display: none;\n  }\n  [data-badge-wrapper=\"true\"] {\n    &:has(+ a:hover) {\n      svg {\n        width: 20px;\n        height: 20px;\n      }\n    }\n  }\n  &:not([data-content-type]) {\n    grid-template-areas: \"badge resourceLink typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    grid-template-areas: \"badge resourceLink resourceType typeWrapper\";\n    grid-row-gap: 0;\n    align-items: center;\n  }\n`;\n\nconst ResourceLink = styled(SafeLink)`\n  grid-area: resourceLink;\n  display: flex;\n  width: 100%;\n  align-items: center;\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  &[data-active=\"false\"] {\n    text-decoration: underline;\n    text-underline-offset: 5px;\n  }\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 TitleContainer = styled.div`\n  align-items: normal;\n  display: flex;\n  flex-direction: column;\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n    flex-direction: row;\n  }\n`;\n\nconst ContentBadgeWrapper = styled.div`\n  grid-area: badge;\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    align-items: center;\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  grid-area: typeWrapper;\n  display: flex;\n  align-items: center;\n  gap: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.desktop })} {\n    align-items: center;\n  }\n`;\n\nconst ContentTypeName = styled.span`\n  grid-area: resourceType;\n  font-family: ${fonts.sans};\n  ${fonts.sizes(\"14px\", \"18px\")};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: left;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-left: 0;\n    text-align: right;\n    margin: 0 ${spacing.xsmall};\n  }\n`;\n\nconst CurrentSmall = styled.small`\n  text-decoration: none;\n  color: ${colors.text.primary};\n  font-weight: ${fonts.weight.normal};\n  white-space: nowrap;\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0 ${spacing.xsmall};\n  }\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  language?: string;\n  access?: \"teacher\";\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  showAdditionalResources,\n  access,\n  language,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  const listElementVars = useMemo(() => {\n    if (!contentType) return {};\n    return {\n      \"--contentTypeBg\": listElementActiveColor(contentType),\n    } 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      data-content-type={contentTypeName}\n      style={listElementVars}\n    >\n      <ContentBadgeWrapper data-badge-wrapper={!active}>\n        <ContentTypeBadge type={contentType ?? \"\"} background border={false} />\n      </ContentBadgeWrapper>\n      <ResourceLink\n        to={path}\n        lang={language === \"nb\" ? \"no\" : language}\n        aria-current={active ? \"page\" : undefined}\n        aria-describedby={describedBy}\n        disabled={active}\n        data-active={active}\n      >\n        <TitleContainer>\n          <div>{name}</div>\n          {active ? <CurrentSmall>{t(\"resource.youAreHere\")}</CurrentSmall> : undefined}\n        </TitleContainer>\n      </ResourceLink>\n      {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n      <TypeWrapper>\n        {access && access === \"teacher\" && (\n          <IconWrapper aria-label={t(\"article.access.onlyTeacher\")} title={t(\"article.access.onlyTeacher\")}>\n            <HumanMaleBoard id={accessId} />\n          </IconWrapper>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <IconWrapper id={additionalId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Additional color={colors.brand.dark} size=\"normal\" />\n              </IconWrapper>\n            )}\n            {!additional && (\n              <IconWrapper id={coreId} aria-label={contentTypeDescription} title={contentTypeDescription}>\n                <Core color={colors.brand.primary} size=\"normal\" />\n              </IconWrapper>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
117
119
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
118
120
  });
119
121
  const ResourceItem = _ref => {
@@ -150,30 +152,33 @@ const ResourceItem = _ref => {
150
152
  hidden: hidden && !active,
151
153
  "data-active": active,
152
154
  "data-additional": additional,
155
+ "data-content-type": contentTypeName,
153
156
  style: listElementVars,
154
- children: [_jsxs(ResourceLink, {
157
+ children: [_jsx(ContentBadgeWrapper, {
158
+ "data-badge-wrapper": !active,
159
+ children: _jsx(ContentTypeBadge, {
160
+ type: contentType ?? "",
161
+ background: true,
162
+ border: false
163
+ })
164
+ }), _jsx(ResourceLink, {
155
165
  to: path,
156
166
  lang: language === "nb" ? "no" : language,
157
167
  "aria-current": active ? "page" : undefined,
158
168
  "aria-describedby": describedBy,
159
169
  disabled: active,
160
170
  "data-active": active,
161
- children: [_jsx(ContentBadgeWrapper, {
162
- "data-badge-wrapper": !active,
163
- children: _jsx(ContentTypeBadge, {
164
- type: contentType ?? "",
165
- background: true,
166
- border: false
167
- })
168
- }), _jsxs(InlineContainer, {
169
- children: [name, active ? _jsx(CurrentSmall, {
171
+ children: _jsxs(TitleContainer, {
172
+ children: [_jsx("div", {
173
+ children: name
174
+ }), active ? _jsx(CurrentSmall, {
170
175
  children: t("resource.youAreHere")
171
176
  }) : undefined]
172
- })]
177
+ })
178
+ }), contentTypeName && _jsx(ContentTypeName, {
179
+ children: contentTypeName
173
180
  }), _jsxs(TypeWrapper, {
174
- children: [contentTypeName && _jsx(ContentTypeName, {
175
- children: contentTypeName
176
- }), access && access === "teacher" && _jsx(IconWrapper, {
181
+ children: [access && access === "teacher" && _jsx(IconWrapper, {
177
182
  "aria-label": t("article.access.onlyTeacher"),
178
183
  title: t("article.access.onlyTeacher"),
179
184
  children: _jsx(HumanMaleBoard, {