@ndla/ui 42.1.2 → 43.0.1

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 (121) hide show
  1. package/es/Article/ArticleNotions.js +46 -53
  2. package/es/AudioPlayer/Controls.js +41 -39
  3. package/es/Breadcrumb/index.js +0 -1
  4. package/es/Filter/FilterButtons.js +49 -53
  5. package/es/Filter/FilterListPhone.js +78 -71
  6. package/es/LanguageSelector/LanguageSelector.js +31 -36
  7. package/es/LearningPaths/LearningPathMenuModalWrapper.js +39 -28
  8. package/es/Masthead/MastheadSearchModal.js +31 -35
  9. package/es/MyNdla/Resource/Folder.js +10 -16
  10. package/es/MyNdla/index.js +1 -3
  11. package/es/NDLAFilm/AboutNdlaFilm.js +16 -20
  12. package/es/NDLAFilm/FilmMovieSearch.js +43 -11
  13. package/es/Resource/BlockResource.js +8 -11
  14. package/es/Resource/ListResource.js +8 -11
  15. package/es/Resource/resourceComponents.js +46 -35
  16. package/es/ResourcesWrapper/ResourcesTopicTitle.js +36 -44
  17. package/es/Search/ToggleSearchButton.js +7 -6
  18. package/es/SearchTypeResult/PopupFilter.js +55 -69
  19. package/es/SearchTypeResult/SearchNotionsResult.js +9 -7
  20. package/es/SearchTypeResult/components/ItemContexts.js +41 -45
  21. package/es/SearchTypeResult/components/SubjectFilters.js +16 -17
  22. package/es/Topic/Topic.js +41 -45
  23. package/es/TreeStructure/FolderItem.js +7 -11
  24. package/es/index.js +2 -2
  25. package/es/locale/messages-en.js +1 -0
  26. package/es/locale/messages-nb.js +1 -0
  27. package/es/locale/messages-nn.js +1 -0
  28. package/es/locale/messages-se.js +1 -0
  29. package/es/locale/messages-sma.js +1 -0
  30. package/lib/Article/ArticleNotions.js +45 -52
  31. package/lib/AudioPlayer/Controls.js +40 -38
  32. package/lib/Breadcrumb/index.d.ts +0 -1
  33. package/lib/Breadcrumb/index.js +0 -7
  34. package/lib/Filter/FilterButtons.js +48 -52
  35. package/lib/Filter/FilterListPhone.js +76 -69
  36. package/lib/LanguageSelector/LanguageSelector.js +31 -36
  37. package/lib/LearningPaths/LearningPathMenuModalWrapper.js +47 -35
  38. package/lib/Masthead/MastheadSearchModal.js +29 -32
  39. package/lib/MyNdla/Resource/Folder.d.ts +3 -4
  40. package/lib/MyNdla/Resource/Folder.js +10 -16
  41. package/lib/MyNdla/index.d.ts +1 -3
  42. package/lib/MyNdla/index.js +0 -14
  43. package/lib/NDLAFilm/AboutNdlaFilm.js +15 -18
  44. package/lib/NDLAFilm/FilmMovieSearch.d.ts +1 -2
  45. package/lib/NDLAFilm/FilmMovieSearch.js +46 -11
  46. package/lib/Resource/BlockResource.d.ts +3 -3
  47. package/lib/Resource/BlockResource.js +8 -11
  48. package/lib/Resource/ListResource.d.ts +3 -3
  49. package/lib/Resource/ListResource.js +8 -11
  50. package/lib/Resource/resourceComponents.js +45 -34
  51. package/lib/ResourcesWrapper/ResourcesTopicTitle.js +35 -42
  52. package/lib/Search/ToggleSearchButton.d.ts +2 -1
  53. package/lib/Search/ToggleSearchButton.js +9 -6
  54. package/lib/SearchTypeResult/PopupFilter.d.ts +1 -3
  55. package/lib/SearchTypeResult/PopupFilter.js +54 -68
  56. package/lib/SearchTypeResult/SearchNotionsResult.js +9 -7
  57. package/lib/SearchTypeResult/components/ItemContexts.js +40 -44
  58. package/lib/SearchTypeResult/components/SubjectFilters.js +16 -17
  59. package/lib/Topic/Topic.js +40 -44
  60. package/lib/TreeStructure/FolderItem.js +7 -11
  61. package/lib/index.d.ts +2 -2
  62. package/lib/index.js +0 -12
  63. package/lib/locale/messages-en.d.ts +1 -0
  64. package/lib/locale/messages-en.js +1 -0
  65. package/lib/locale/messages-nb.d.ts +1 -0
  66. package/lib/locale/messages-nb.js +1 -0
  67. package/lib/locale/messages-nn.d.ts +1 -0
  68. package/lib/locale/messages-nn.js +1 -0
  69. package/lib/locale/messages-se.d.ts +1 -0
  70. package/lib/locale/messages-se.js +1 -0
  71. package/lib/locale/messages-sma.d.ts +1 -0
  72. package/lib/locale/messages-sma.js +1 -0
  73. package/package.json +11 -12
  74. package/src/Article/ArticleNotions.tsx +29 -35
  75. package/src/AudioPlayer/Controls.tsx +22 -26
  76. package/src/Breadcrumb/index.ts +0 -2
  77. package/src/Filter/FilterButtons.tsx +28 -34
  78. package/src/Filter/FilterListPhone.tsx +63 -62
  79. package/src/LanguageSelector/LanguageSelector.tsx +26 -32
  80. package/src/LearningPaths/LearningPathMenuModalWrapper.tsx +19 -18
  81. package/src/Masthead/MastheadSearchModal.tsx +21 -29
  82. package/src/MyNdla/Resource/Folder.stories.tsx +27 -5
  83. package/src/MyNdla/Resource/Folder.tsx +4 -19
  84. package/src/MyNdla/index.ts +1 -3
  85. package/src/NDLAFilm/AboutNdlaFilm.tsx +11 -10
  86. package/src/NDLAFilm/FilmMovieSearch.tsx +32 -9
  87. package/src/Resource/BlockResource.stories.tsx +1 -1
  88. package/src/Resource/BlockResource.tsx +4 -6
  89. package/src/Resource/ListResource.tsx +4 -6
  90. package/src/Resource/Resource.stories.tsx +32 -2
  91. package/src/Resource/resourceComponents.tsx +34 -24
  92. package/src/ResourcesWrapper/ResourcesTopicTitle.tsx +23 -27
  93. package/src/Search/ToggleSearchButton.tsx +15 -12
  94. package/src/SearchTypeResult/PopupFilter.tsx +55 -70
  95. package/src/SearchTypeResult/SearchNotionsResult.tsx +5 -2
  96. package/src/SearchTypeResult/components/ItemContexts.tsx +23 -28
  97. package/src/SearchTypeResult/components/SubjectFilters.tsx +9 -12
  98. package/src/Topic/Topic.tsx +15 -17
  99. package/src/TreeStructure/FolderItem.tsx +2 -4
  100. package/src/index.ts +2 -2
  101. package/src/locale/messages-en.ts +1 -0
  102. package/src/locale/messages-nb.ts +1 -0
  103. package/src/locale/messages-nn.ts +1 -0
  104. package/src/locale/messages-se.ts +1 -0
  105. package/src/locale/messages-sma.ts +1 -0
  106. package/es/Breadcrumb/ActionBreadcrumb.js +0 -74
  107. package/es/MyNdla/Resource/FolderMenu.js +0 -74
  108. package/es/MyNdla/SettingsMenu.js +0 -98
  109. package/es/NDLAFilm/CategorySelect.js +0 -135
  110. package/lib/Breadcrumb/ActionBreadcrumb.d.ts +0 -15
  111. package/lib/Breadcrumb/ActionBreadcrumb.js +0 -82
  112. package/lib/MyNdla/Resource/FolderMenu.d.ts +0 -16
  113. package/lib/MyNdla/Resource/FolderMenu.js +0 -81
  114. package/lib/MyNdla/SettingsMenu.d.ts +0 -15
  115. package/lib/MyNdla/SettingsMenu.js +0 -102
  116. package/lib/NDLAFilm/CategorySelect.d.ts +0 -16
  117. package/lib/NDLAFilm/CategorySelect.js +0 -144
  118. package/src/Breadcrumb/ActionBreadcrumb.tsx +0 -87
  119. package/src/MyNdla/Resource/FolderMenu.tsx +0 -102
  120. package/src/MyNdla/SettingsMenu.tsx +0 -96
  121. package/src/NDLAFilm/CategorySelect.tsx +0 -197
@@ -10,10 +10,10 @@ var _core = require("@ndla/core");
10
10
  var _react = _interopRequireWildcard(require("react"));
11
11
  var _reactI18next = require("react-i18next");
12
12
  var _button = require("@ndla/button");
13
- var _safelink = _interopRequireDefault(require("@ndla/safelink"));
14
- var _reactRouterDom = require("react-router-dom");
13
+ var _safelink = _interopRequireWildcard(require("@ndla/safelink"));
15
14
  var _common = require("@ndla/icons/common");
16
15
  var _react2 = require("@emotion/react");
16
+ var _dropdownMenu = require("@ndla/dropdown-menu");
17
17
  var _resourceTypeColor = _interopRequireDefault(require("../utils/resourceTypeColor"));
18
18
  var _ContentType = require("../model/ContentType");
19
19
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
@@ -36,24 +36,28 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
36
36
  *
37
37
  */
38
38
  var ResourceTitleLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
39
- target: "e1lrrm6s8",
39
+ target: "e1lrrm6s9",
40
40
  label: "ResourceTitleLink"
41
- })("box-shadow:none;color:", _core.colors.brand.primary, ";flex:1;:after{content:'';position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyBiD","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
41
+ })("box-shadow:none;color:", _core.colors.brand.primary, ";flex:1;:after{content:'';position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyBiD","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
42
42
  exports.ResourceTitleLink = ResourceTitleLink;
43
- var resourceHeadingStyle = /*#__PURE__*/(0, _react2.css)("margin:0;overflow:hidden;text-overflow:ellipsis;font-weight:", _core.fonts.weight.bold, ";line-height:1;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;grid-area:resourceTitle;", _core.fonts.sizes('16px', '20px'), ";;label:resourceHeadingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwCuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
43
+ var StyledTrigger = /*#__PURE__*/(0, _base.default)(_button.IconButtonV2, {
44
+ target: "e1lrrm6s8",
45
+ label: "StyledTrigger"
46
+ })("margin:0px ", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwC0C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
47
+ var resourceHeadingStyle = /*#__PURE__*/(0, _react2.css)("margin:0;overflow:hidden;text-overflow:ellipsis;font-weight:", _core.fonts.weight.bold, ";line-height:1;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;grid-area:resourceTitle;", _core.fonts.sizes('16px', '20px'), ";;label:resourceHeadingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA4CuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
44
48
  exports.resourceHeadingStyle = resourceHeadingStyle;
45
49
  var StyledTagList = /*#__PURE__*/(0, _base.default)("ul", {
46
50
  target: "e1lrrm6s7",
47
51
  label: "StyledTagList"
48
- })("list-style:none;display:flex;margin:0;margin-left:", _core.spacing.small, ";padding:2px;gap:", _core.spacing.xsmall, ";overflow:hidden;:last-child{margin-right:", _core.spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAuD+B","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
52
+ })("list-style:none;display:flex;margin:0;margin-left:", _core.spacing.small, ";padding:2px;gap:", _core.spacing.xsmall, ";overflow:hidden;:last-child{margin-right:", _core.spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA2D+B","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
49
53
  var StyledTagListElement = /*#__PURE__*/(0, _base.default)("li", {
50
54
  target: "e1lrrm6s6",
51
55
  label: "StyledTagListElement"
52
- })("margin:0;", _core.fonts.sizes(14), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAoEsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
56
+ })("margin:0;", _core.fonts.sizes(14), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwEsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
53
57
  var StyledSafeLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
54
58
  target: "e1lrrm6s5",
55
59
  label: "StyledSafeLink"
56
- })("display:flex;justify-content:flex-end;align-items:center;box-shadow:none;color:", _core.colors.brand.grey, ";min-height:44px;min-width:44px;white-space:nowrap;&:hover{color:", _core.colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyEuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
60
+ })("display:flex;justify-content:flex-end;align-items:center;box-shadow:none;color:", _core.colors.brand.grey, ";min-height:44px;min-width:44px;white-space:nowrap;&:hover{color:", _core.colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA6EuC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
57
61
  var StyledResourceTypeList = /*#__PURE__*/(0, _base.default)("ul", {
58
62
  target: "e1lrrm6s4",
59
63
  label: "StyledResourceTypeList"
@@ -63,21 +67,21 @@ var StyledResourceTypeList = /*#__PURE__*/(0, _base.default)("ul", {
63
67
  } : {
64
68
  name: "vspsww",
65
69
  styles: "list-style:none;display:flex;margin:0;padding:0;overflow:hidden",
66
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAuFwC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
70
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA2FwC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
67
71
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
68
72
  });
69
73
  var StyledTopicDivider = /*#__PURE__*/(0, _base.default)("span", {
70
74
  target: "e1lrrm6s3",
71
75
  label: "StyledTopicDivider"
72
- })("margin:0;padding:0 ", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA+FsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
76
+ })("margin:0;padding:0 ", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAmGsC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
73
77
  var StyledResourceListElement = /*#__PURE__*/(0, _base.default)("li", {
74
78
  target: "e1lrrm6s2",
75
79
  label: "StyledResourceListElement"
76
- })("white-space:nowrap;", _core.fonts.sizes(12), ";margin:0;line-height:1.5;padding:0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAoG2C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
80
+ })("white-space:nowrap;", _core.fonts.sizes(12), ";margin:0;line-height:1.5;padding:0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAwG2C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
77
81
  var TagCounterWrapper = /*#__PURE__*/(0, _base.default)("span", {
78
82
  target: "e1lrrm6s1",
79
83
  label: "TagCounterWrapper"
80
- })("display:flex;font-weight:", _core.fonts.weight.semibold, ";", _core.fonts.sizes('14px', '14px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA8GqC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
84
+ })("display:flex;font-weight:", _core.fonts.weight.semibold, ";", _core.fonts.sizes('14px', '14px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAkHqC","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */"));
81
85
  var StyledContentIconWrapper = /*#__PURE__*/(0, _base.default)("span", {
82
86
  target: "e1lrrm6s0",
83
87
  label: "StyledContentIconWrapper"
@@ -87,7 +91,7 @@ var StyledContentIconWrapper = /*#__PURE__*/(0, _base.default)("span", {
87
91
  } : {
88
92
  name: "758j4h",
89
93
  styles: "width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background-color:var(--content-background-color)",
90
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AAyH4C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { MenuButton } from '@ndla/button';\nimport SafeLink from '@ndla/safelink';\nimport { useNavigate } from 'react-router-dom';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const navigate = useNavigate();\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(\n    () =>\n      tags.slice(3, tags.length).map((tag) => {\n        return {\n          icon: <HashTag />,\n          text: tag,\n          onClick: () => {\n            navigate(`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`);\n          },\n        };\n      }),\n    [navigate, tagLinkPrefix, tags],\n  );\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <MenuButton\n          size=\"small\"\n          menuIcon={<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n          menuItems={remainingTags}\n          align=\"end\"\n          aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n        />\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
94
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resourceComponents.tsx"],"names":[],"mappings":"AA6H4C","file":"resourceComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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 styled from '@emotion/styled';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport React, { CSSProperties, HTMLAttributes, ReactNode, useMemo } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { IconButtonV2 } from '@ndla/button';\nimport SafeLink, { SafeLinkButton } from '@ndla/safelink';\nimport { HashTag } from '@ndla/icons/common';\nimport { css } from '@emotion/react';\nimport { DropdownMenu, DropdownContent, DropdownTrigger, DropdownItem } from '@ndla/dropdown-menu';\nimport resourceTypeColor from '../utils/resourceTypeColor';\nimport { resourceEmbedTypeMapping } from '../model/ContentType';\n\nexport interface ResourceImageProps {\n  alt: string;\n  src: string;\n}\n\nexport const ResourceTitleLink = styled(SafeLink)`\n  box-shadow: none;\n  color: ${colors.brand.primary};\n  flex: 1;\n  :after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n  }\n`;\n\nconst StyledTrigger = styled(IconButtonV2)`\n  margin: 0px ${spacing.xsmall};\n`;\n\nexport const resourceHeadingStyle = css`\n  margin: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  font-weight: ${fonts.weight.bold};\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  line-height: 1;\n  display: -webkit-box;\n  -webkit-line-clamp: 1;\n  line-clamp: 1;\n  -webkit-box-orient: vertical;\n  grid-area: resourceTitle;\n  ${fonts.sizes('16px', '20px')};\n`;\n\nconst StyledTagList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  margin-left: ${spacing.small};\n  padding: 2px;\n  gap: ${spacing.xsmall};\n  overflow: hidden;\n  :last-child {\n    margin-right: ${spacing.small};\n  }\n`;\n\nconst StyledTagListElement = styled.li`\n  margin: 0;\n  ${fonts.sizes(14)};\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  box-shadow: none;\n  color: ${colors.brand.grey};\n  min-height: 44px;\n  min-width: 44px;\n  white-space: nowrap;\n  &:hover {\n    color: ${colors.brand.primary};\n  }\n`;\n\nconst StyledResourceTypeList = styled.ul`\n  list-style: none;\n  display: flex;\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n`;\n\nconst StyledTopicDivider = styled.span`\n  margin: 0;\n  padding: 0 ${spacing.xxsmall};\n`;\n\nconst StyledResourceListElement = styled.li`\n  white-space: nowrap;\n  ${fonts.sizes(12)};\n  margin: 0;\n  line-height: 1.5;\n  padding: 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst TagCounterWrapper = styled.span`\n  display: flex;\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('14px', '14px')};\n`;\n\ninterface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {\n  contentType: string;\n  children?: ReactNode;\n}\n\nconst StyledContentIconWrapper = styled.span`\n  width: 100%;\n  aspect-ratio: 4/3;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: var(--content-background-color);\n`;\n\nexport const ContentIconWrapper = ({ contentType, children, ...props }: ContentIconProps) => {\n  const contentIconWrapperVars = useMemo(\n    () => ({ '--content-background-color': resourceTypeColor(contentType) } as unknown as CSSProperties),\n    [contentType],\n  );\n  return (\n    <StyledContentIconWrapper {...props} style={contentIconWrapperVars}>\n      {children}\n    </StyledContentIconWrapper>\n  );\n};\n\ninterface TagListProps {\n  tags?: string[];\n  tagLinkPrefix?: string;\n}\n\nexport interface LoaderProps {\n  loading?: boolean;\n  children?: ReactNode;\n}\n\nexport const TagList = ({ tags, tagLinkPrefix }: TagListProps) => {\n  const { t } = useTranslation();\n  if (!tags) return null;\n  return (\n    <StyledTagList aria-label={t('myNdla.tagList')}>\n      {tags.map((tag, i) => (\n        <StyledTagListElement key={`tag-${i}`}>\n          <StyledSafeLink to={`${tagLinkPrefix ? tagLinkPrefix : ''}/${encodeURIComponent(tag)}`}>\n            <HashTag />\n            {tag}\n          </StyledSafeLink>\n        </StyledTagListElement>\n      ))}\n    </StyledTagList>\n  );\n};\n\ninterface CompressedTagListProps {\n  tags: string[];\n  tagLinkPrefix?: string;\n}\n\nexport const CompressedTagList = ({ tags, tagLinkPrefix }: CompressedTagListProps) => {\n  const { t } = useTranslation();\n  const visibleTags = useMemo(() => tags.slice(0, 3), [tags]);\n  const remainingTags = useMemo(() => tags.slice(3, tags.length), [tags]);\n\n  return (\n    <>\n      <TagList tagLinkPrefix={tagLinkPrefix} tags={visibleTags} />\n      {remainingTags.length > 0 && (\n        <DropdownMenu>\n          <DropdownTrigger>\n            <StyledTrigger\n              size=\"xsmall\"\n              variant=\"ghost\"\n              colorTheme=\"light\"\n              aria-label={t('myNdla.moreTags', { count: remainingTags.length })}\n            >\n              {<TagCounterWrapper>{`+${remainingTags.length}`}</TagCounterWrapper>}\n            </StyledTrigger>\n          </DropdownTrigger>\n          <DropdownContent showArrow>\n            {remainingTags.map((tag, i) => (\n              <DropdownItem key={`tag-${i}`}>\n                <SafeLinkButton\n                  to={`${tagLinkPrefix ?? ''}/${encodeURIComponent(tag)}`}\n                  variant=\"ghost\"\n                  colorTheme=\"light\"\n                >\n                  <HashTag />\n                  {tag}\n                </SafeLinkButton>\n              </DropdownItem>\n            ))}\n          </DropdownContent>\n        </DropdownMenu>\n      )}\n    </>\n  );\n};\n\ninterface ResourceTypeListProps {\n  resourceTypes?: { id: string; name: string }[];\n}\n\nexport const ResourceTypeList = ({ resourceTypes }: ResourceTypeListProps) => {\n  const { t } = useTranslation();\n  if (!resourceTypes) return null;\n  return (\n    <StyledResourceTypeList aria-label={t('navigation.topics')}>\n      {resourceTypes.map((resource, i) => (\n        <StyledResourceListElement key={resource.id}>\n          {resourceEmbedTypeMapping[resource.id]\n            ? t(`embed.type.${resourceEmbedTypeMapping[resource.id]}`)\n            : resource.name}\n          {i !== resourceTypes.length - 1 && <StyledTopicDivider aria-hidden=\"true\">•</StyledTopicDivider>}\n        </StyledResourceListElement>\n      ))}\n    </StyledResourceTypeList>\n  );\n};\n"]} */",
91
95
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
92
96
  });
93
97
  var ContentIconWrapper = function ContentIconWrapper(_ref) {
@@ -127,37 +131,44 @@ exports.TagList = TagList;
127
131
  var CompressedTagList = function CompressedTagList(_ref3) {
128
132
  var tags = _ref3.tags,
129
133
  tagLinkPrefix = _ref3.tagLinkPrefix;
130
- var navigate = (0, _reactRouterDom.useNavigate)();
131
134
  var _useTranslation2 = (0, _reactI18next.useTranslation)(),
132
135
  t = _useTranslation2.t;
133
136
  var visibleTags = (0, _react.useMemo)(function () {
134
137
  return tags.slice(0, 3);
135
138
  }, [tags]);
136
139
  var remainingTags = (0, _react.useMemo)(function () {
137
- return tags.slice(3, tags.length).map(function (tag) {
138
- return {
139
- icon: (0, _jsxRuntime.jsx)(_common.HashTag, {}),
140
- text: tag,
141
- onClick: function onClick() {
142
- navigate("".concat(tagLinkPrefix ? tagLinkPrefix : '', "/").concat(encodeURIComponent(tag)));
143
- }
144
- };
145
- });
146
- }, [navigate, tagLinkPrefix, tags]);
140
+ return tags.slice(3, tags.length);
141
+ }, [tags]);
147
142
  return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
148
143
  children: [(0, _jsxRuntime.jsx)(TagList, {
149
144
  tagLinkPrefix: tagLinkPrefix,
150
145
  tags: visibleTags
151
- }), remainingTags.length > 0 && (0, _jsxRuntime.jsx)(_button.MenuButton, {
152
- size: "small",
153
- menuIcon: (0, _jsxRuntime.jsx)(TagCounterWrapper, {
154
- children: "+".concat(remainingTags.length)
155
- }),
156
- menuItems: remainingTags,
157
- align: "end",
158
- "aria-label": t('myNdla.moreTags', {
159
- count: remainingTags.length
160
- })
146
+ }), remainingTags.length > 0 && (0, _jsxRuntime.jsxs)(_dropdownMenu.DropdownMenu, {
147
+ children: [(0, _jsxRuntime.jsx)(_dropdownMenu.DropdownTrigger, {
148
+ children: (0, _jsxRuntime.jsx)(StyledTrigger, {
149
+ size: "xsmall",
150
+ variant: "ghost",
151
+ colorTheme: "light",
152
+ "aria-label": t('myNdla.moreTags', {
153
+ count: remainingTags.length
154
+ }),
155
+ children: (0, _jsxRuntime.jsx)(TagCounterWrapper, {
156
+ children: "+".concat(remainingTags.length)
157
+ })
158
+ })
159
+ }), (0, _jsxRuntime.jsx)(_dropdownMenu.DropdownContent, {
160
+ showArrow: true,
161
+ children: remainingTags.map(function (tag, i) {
162
+ return (0, _jsxRuntime.jsx)(_dropdownMenu.DropdownItem, {
163
+ children: (0, _jsxRuntime.jsxs)(_safelink.SafeLinkButton, {
164
+ to: "".concat(tagLinkPrefix !== null && tagLinkPrefix !== void 0 ? tagLinkPrefix : '', "/").concat(encodeURIComponent(tag)),
165
+ variant: "ghost",
166
+ colorTheme: "light",
167
+ children: [(0, _jsxRuntime.jsx)(_common.HashTag, {}), tag]
168
+ })
169
+ }, "tag-".concat(i));
170
+ })
171
+ })]
161
172
  })]
162
173
  });
163
174
  };