@ndla/ui 42.1.1 → 43.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/es/AudioPlayer/AudioPlayer.js +27 -33
  2. package/es/AudioPlayer/Controls.js +41 -39
  3. package/es/Breadcrumb/index.js +0 -1
  4. package/es/CampaignBlock/CampaignBlock.js +32 -18
  5. package/es/LanguageSelector/LanguageSelector.js +31 -36
  6. package/es/LicenseByline/EmbedByline.js +5 -5
  7. package/es/MyNdla/Resource/Folder.js +27 -72
  8. package/es/MyNdla/index.js +1 -3
  9. package/es/Resource/BlockResource.js +15 -27
  10. package/es/Resource/ListResource.js +14 -19
  11. package/es/Resource/resourceComponents.js +82 -41
  12. package/es/TreeStructure/ComboboxButton.js +17 -20
  13. package/es/TreeStructure/FolderItem.js +42 -69
  14. package/es/TreeStructure/FolderItems.js +25 -19
  15. package/es/TreeStructure/TreeStructure.js +19 -26
  16. package/es/index.js +2 -2
  17. package/lib/AudioPlayer/AudioPlayer.js +27 -33
  18. package/lib/AudioPlayer/Controls.js +40 -38
  19. package/lib/Breadcrumb/index.d.ts +0 -1
  20. package/lib/Breadcrumb/index.js +0 -7
  21. package/lib/CampaignBlock/CampaignBlock.js +32 -18
  22. package/lib/LanguageSelector/LanguageSelector.js +31 -36
  23. package/lib/LicenseByline/EmbedByline.js +5 -5
  24. package/lib/MyNdla/Resource/Folder.d.ts +3 -4
  25. package/lib/MyNdla/Resource/Folder.js +27 -72
  26. package/lib/MyNdla/index.d.ts +1 -3
  27. package/lib/MyNdla/index.js +0 -14
  28. package/lib/Resource/BlockResource.d.ts +3 -3
  29. package/lib/Resource/BlockResource.js +14 -26
  30. package/lib/Resource/ListResource.d.ts +3 -3
  31. package/lib/Resource/ListResource.js +13 -18
  32. package/lib/Resource/resourceComponents.d.ts +5 -10
  33. package/lib/Resource/resourceComponents.js +85 -42
  34. package/lib/TreeStructure/ComboboxButton.js +17 -20
  35. package/lib/TreeStructure/FolderItem.js +40 -67
  36. package/lib/TreeStructure/FolderItems.js +31 -26
  37. package/lib/TreeStructure/TreeStructure.js +19 -26
  38. package/lib/index.d.ts +2 -2
  39. package/lib/index.js +0 -12
  40. package/package.json +16 -17
  41. package/src/AudioPlayer/AudioPlayer.tsx +24 -34
  42. package/src/AudioPlayer/Controls.tsx +22 -26
  43. package/src/Breadcrumb/index.ts +0 -2
  44. package/src/CampaignBlock/CampaignBlock.tsx +10 -10
  45. package/src/LanguageSelector/LanguageSelector.tsx +26 -32
  46. package/src/LicenseByline/EmbedByline.tsx +1 -1
  47. package/src/MyNdla/Resource/Folder.stories.tsx +27 -5
  48. package/src/MyNdla/Resource/Folder.tsx +32 -54
  49. package/src/MyNdla/index.ts +1 -3
  50. package/src/Resource/BlockResource.stories.tsx +1 -1
  51. package/src/Resource/BlockResource.tsx +25 -24
  52. package/src/Resource/ListResource.tsx +21 -18
  53. package/src/Resource/Resource.stories.tsx +32 -2
  54. package/src/Resource/resourceComponents.tsx +55 -26
  55. package/src/TreeStructure/ComboboxButton.tsx +5 -7
  56. package/src/TreeStructure/FolderItem.tsx +50 -35
  57. package/src/TreeStructure/FolderItems.tsx +6 -8
  58. package/src/TreeStructure/TreeStructure.tsx +16 -25
  59. package/src/index.ts +2 -2
  60. package/es/Breadcrumb/ActionBreadcrumb.js +0 -74
  61. package/es/MyNdla/Resource/FolderMenu.js +0 -74
  62. package/es/MyNdla/SettingsMenu.js +0 -98
  63. package/lib/Breadcrumb/ActionBreadcrumb.d.ts +0 -15
  64. package/lib/Breadcrumb/ActionBreadcrumb.js +0 -82
  65. package/lib/MyNdla/Resource/FolderMenu.d.ts +0 -16
  66. package/lib/MyNdla/Resource/FolderMenu.js +0 -81
  67. package/lib/MyNdla/SettingsMenu.d.ts +0 -15
  68. package/lib/MyNdla/SettingsMenu.js +0 -102
  69. package/src/Breadcrumb/ActionBreadcrumb.tsx +0 -87
  70. package/src/MyNdla/Resource/FolderMenu.tsx +0 -102
  71. package/src/MyNdla/SettingsMenu.tsx +0 -96
@@ -11,11 +11,10 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
11
11
  import React from 'react';
12
12
  import { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';
13
13
  import Image from '../Image';
14
- import { CompressedTagList, ResourceTitle, ResourceTitleLink as StyledLink, ResourceTypeList, StyledContentIconWrapper } from './resourceComponents';
14
+ import { CompressedTagList, resourceHeadingStyle, ResourceTitleLink as StyledLink, ResourceTypeList, ContentIconWrapper } from './resourceComponents';
15
15
  import ContentLoader from '../ContentLoader';
16
16
  import ContentTypeBadge from '../ContentTypeBadge';
17
17
  import { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';
18
- import { SettingsMenu } from '../MyNdla';
19
18
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
20
19
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
21
20
  import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
@@ -24,17 +23,13 @@ var ListResourceWrapper = /*#__PURE__*/_styled("div", {
24
23
  label: "ListResourceWrapper"
25
24
  })("flex:1;display:grid;position:relative;grid-template-columns:auto minmax(50px, 1fr) auto;grid-template-areas:'image topicAndTitle tags' 'image description description';", mq.range({
26
25
  until: breakpoints.mobileWide
27
- }), "{grid-template-columns:auto 1fr;grid-template-areas:'image topicAndTitle' 'description description' 'tags tags';}cursor:pointer;border:1px solid ", colors.brand.neutral7, ";border-radius:2px;&:hover{box-shadow:1px 1px 6px 2px rgba(9, 55, 101, 0.08);transition-duration:0.2s;", function () {
28
- return StyledLink;
29
- }, "{color:", colors.brand.primary, ";text-decoration:underline;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA2BsC","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
26
+ }), "{grid-template-columns:auto 1fr;grid-template-areas:'image topicAndTitle' 'description description' 'tags tags';}cursor:pointer;border:1px solid ", colors.brand.neutral7, ";border-radius:2px;&:hover{box-shadow:1px 1px 6px 2px rgba(9, 55, 101, 0.08);transition-duration:0.2s;[data-link]{color:", colors.brand.primary, ";text-decoration:underline;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAyBsC","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
30
27
  var ImageWrapper = /*#__PURE__*/_styled("div", {
31
28
  target: "e18z2zfy4",
32
29
  label: "ImageWrapper"
33
- })("grid-area:image;width:", function (p) {
34
- return p.imageSize === 'normal' ? '136px' : '56px';
35
- }, ";", mq.range({
30
+ })("grid-area:image;width:56px;overflow:hidden;border-radius:2px;display:flex;margin:", spacing.small, ";align-items:center;justify-content:center;aspect-ratio:4/3;&[data-image-size='normal']{width:136px;}", mq.range({
36
31
  until: breakpoints.mobileWide
37
- }), "{width:56px;margin-bottom:0;}overflow:hidden;border-radius:2px;display:flex;margin:", spacing.small, ";align-items:center;justify-content:center;aspect-ratio:4/3;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA6DiD","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
32
+ }), "{width:56px;margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA2DiD","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
38
33
  var StyledImage = /*#__PURE__*/_styled(Image, {
39
34
  target: "e18z2zfy3",
40
35
  label: "StyledImage"
@@ -44,7 +39,7 @@ var StyledImage = /*#__PURE__*/_styled(Image, {
44
39
  } : {
45
40
  name: "ie7djk",
46
41
  styles: "object-fit:cover;aspect-ratio:4/3",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA6EiC","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */",
42
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA8EiC","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */",
48
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
44
  });
50
45
  var StyledResourceDescription = /*#__PURE__*/_styled("p", {
@@ -52,19 +47,19 @@ var StyledResourceDescription = /*#__PURE__*/_styled("p", {
52
47
  label: "StyledResourceDescription"
53
48
  })("grid-area:description;line-clamp:2;line-height:1em;height:3.1em;margin:0 ", spacing.small, " ", spacing.small, " 0;", mq.range({
54
49
  until: breakpoints.mobileWide
55
- }), "{margin:0 ", spacing.small, ";}overflow:hidden;", fonts.sizes(16), ";text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAkF0C","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
50
+ }), "{margin:0 ", spacing.small, ";}overflow:hidden;", fonts.sizes(16), ";text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAmF0C","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
56
51
  var TagsandActionMenu = /*#__PURE__*/_styled("div", {
57
52
  target: "e18z2zfy1",
58
53
  label: "TagsandActionMenu"
59
54
  })("grid-area:tags;z-index:1;box-sizing:content-box;display:grid;grid-template-columns:1fr auto auto;align-items:center;align-self:flex-start;justify-items:flex-end;overflow:hidden;", mq.range({
60
55
  until: breakpoints.mobileWide
61
- }), "{min-height:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAqGoC","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
56
+ }), "{min-height:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAsGoC","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
62
57
  var TopicAndTitleWrapper = /*#__PURE__*/_styled("div", {
63
58
  target: "e18z2zfy0",
64
59
  label: "TopicAndTitleWrapper"
65
60
  })("grid-area:topicAndTitle;display:flex;margin:", spacing.small, " 0;flex-direction:column;overflow:hidden;margin-right:", spacing.small, ";", mq.range({
66
61
  until: breakpoints.mobileWide
67
- }), "{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAoHuC","file":"ListResource.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 React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <ResourceTitle title={title}>{title}</ResourceTitle>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
62
+ }), "{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAqHuC","file":"ListResource.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 React, { ReactNode } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  resourceHeadingStyle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  LoaderProps,\n  ContentIconWrapper,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping, resourceEmbedTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    [data-link] {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: 56px;\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n  &[data-image-size='normal'] {\n    width: 136px;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n  background?: boolean;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType, background }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <ContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} background={background} size=\"x-small\" />\n        </ContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menu?: ReactNode;\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  description,\n  menu,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const embedResourceType = resourceEmbedTypeMapping[firstContentType];\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} data-link=\"\" target={targetBlank ? '_blank' : undefined}>\n            <h1 css={resourceHeadingStyle} title={title}>\n              {title}\n            </h1>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menu}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
68
63
  var ListResourceImage = function ListResourceImage(_ref) {
69
64
  var resourceImage = _ref.resourceImage,
70
65
  loading = _ref.loading,
@@ -73,7 +68,7 @@ var ListResourceImage = function ListResourceImage(_ref) {
73
68
  background = _ref.background;
74
69
  if (!loading) {
75
70
  if (resourceImage.src === '') {
76
- return _jsx(StyledContentIconWrapper, {
71
+ return _jsx(ContentIconWrapper, {
77
72
  contentType: contentType,
78
73
  children: _jsx(ContentTypeBadge, {
79
74
  type: contentType,
@@ -172,7 +167,7 @@ var ListResource = function ListResource(_ref4) {
172
167
  resourceImage = _ref4.resourceImage,
173
168
  resourceTypes = _ref4.resourceTypes,
174
169
  description = _ref4.description,
175
- menuItems = _ref4.menuItems,
170
+ menu = _ref4.menu,
176
171
  _ref4$isLoading = _ref4.isLoading,
177
172
  isLoading = _ref4$isLoading === void 0 ? false : _ref4$isLoading,
178
173
  targetBlank = _ref4.targetBlank;
@@ -196,8 +191,10 @@ var ListResource = function ListResource(_ref4) {
196
191
  loading: isLoading,
197
192
  children: [_jsx(StyledLink, {
198
193
  to: link,
194
+ "data-link": "",
199
195
  target: targetBlank ? '_blank' : undefined,
200
- children: _jsx(ResourceTitle, {
196
+ children: _jsx("h1", {
197
+ css: resourceHeadingStyle,
201
198
  title: title,
202
199
  children: title
203
200
  })
@@ -212,9 +209,7 @@ var ListResource = function ListResource(_ref4) {
212
209
  children: [tags && tags.length > 0 && _jsx(CompressedTagList, {
213
210
  tagLinkPrefix: tagLinkPrefix,
214
211
  tags: tags
215
- }), menuItems && menuItems.length > 0 && _jsx(SettingsMenu, {
216
- menuItems: menuItems
217
- })]
212
+ }), menu]
218
213
  })]
219
214
  });
220
215
  };