@ndla/ui 55.0.10-alpha.0 → 55.0.11-alpha.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 (40) hide show
  1. package/es/index.js +0 -2
  2. package/lib/index.d.ts +0 -3
  3. package/lib/index.js +0 -20
  4. package/package.json +8 -8
  5. package/src/index.ts +0 -3
  6. package/es/MyNdla/Resource/Folder.js +0 -135
  7. package/es/MyNdla/Resource/index.js +0 -10
  8. package/es/MyNdla/index.js +0 -10
  9. package/es/Resource/BlockResource.js +0 -204
  10. package/es/Resource/ListResource.js +0 -235
  11. package/es/Resource/index.js +0 -10
  12. package/es/Resource/resourceComponents.js +0 -179
  13. package/es/Resource/storyComponents.js +0 -64
  14. package/lib/MyNdla/Resource/Folder.d.ts +0 -24
  15. package/lib/MyNdla/Resource/Folder.js +0 -142
  16. package/lib/MyNdla/Resource/index.d.ts +0 -9
  17. package/lib/MyNdla/Resource/index.js +0 -13
  18. package/lib/MyNdla/index.d.ts +0 -9
  19. package/lib/MyNdla/index.js +0 -13
  20. package/lib/Resource/BlockResource.d.ts +0 -28
  21. package/lib/Resource/BlockResource.js +0 -208
  22. package/lib/Resource/ListResource.d.ts +0 -28
  23. package/lib/Resource/ListResource.js +0 -239
  24. package/lib/Resource/index.d.ts +0 -11
  25. package/lib/Resource/index.js +0 -20
  26. package/lib/Resource/resourceComponents.d.ts +0 -43
  27. package/lib/Resource/resourceComponents.js +0 -188
  28. package/lib/Resource/storyComponents.d.ts +0 -12
  29. package/lib/Resource/storyComponents.js +0 -71
  30. package/src/MyNdla/Resource/Folder.stories.tsx +0 -87
  31. package/src/MyNdla/Resource/Folder.tsx +0 -228
  32. package/src/MyNdla/Resource/index.ts +0 -10
  33. package/src/MyNdla/index.ts +0 -10
  34. package/src/Resource/BlockResource.stories.tsx +0 -98
  35. package/src/Resource/BlockResource.tsx +0 -212
  36. package/src/Resource/ListResource.stories.tsx +0 -99
  37. package/src/Resource/ListResource.tsx +0 -273
  38. package/src/Resource/index.ts +0 -12
  39. package/src/Resource/resourceComponents.tsx +0 -242
  40. package/src/Resource/storyComponents.tsx +0 -49
@@ -1,239 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _react = require("react");
9
- var _core = require("@ndla/core");
10
- var _typography = require("@ndla/typography");
11
- var _resourceComponents = require("./resourceComponents");
12
- var _ContentLoader = _interopRequireDefault(require("../ContentLoader"));
13
- var _ContentTypeBadge = _interopRequireDefault(require("../ContentTypeBadge"));
14
- var _Image = _interopRequireDefault(require("../Image"));
15
- var _ContentType = require("../model/ContentType");
16
- var _jsxRuntime = require("@emotion/react/jsx-runtime");
17
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
18
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /**
19
- * Copyright (c) 2022-present, NDLA.
20
- *
21
- * This source code is licensed under the GPLv3 license found in the
22
- * LICENSE file in the root directory of this source tree.
23
- *
24
- */ /** @jsxImportSource @emotion/react */
25
- const ListResourceWrapper = /*#__PURE__*/(0, _base.default)("div", {
26
- target: "e18z2zfy5",
27
- label: "ListResourceWrapper"
28
- })("flex:1;display:grid;position:relative;grid-template-columns:auto minmax(50px, 1fr) auto;grid-template-areas:\"image topicAndTitle tags\" \"image description description\";", _core.mq.range({
29
- until: _core.breakpoints.mobileWide
30
- }), "{grid-template-columns:auto 1fr;grid-template-areas:\"image topicAndTitle\" \"description description\" \"tags tags\";}cursor:pointer;border:1px solid ", _core.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:", _core.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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */"));
31
- const ImageWrapper = /*#__PURE__*/(0, _base.default)("div", {
32
- target: "e18z2zfy4",
33
- label: "ImageWrapper"
34
- })("grid-area:image;width:56px;overflow:hidden;border-radius:2px;display:flex;margin:", _core.spacing.small, ";align-items:center;justify-content:center;aspect-ratio:4/3;&[data-image-size=\"normal\"]{width:136px;}", _core.mq.range({
35
- until: _core.breakpoints.mobileWide
36
- }), "{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":"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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */"));
37
- const StyledImage = /*#__PURE__*/(0, _base.default)(_Image.default, {
38
- target: "e18z2zfy3",
39
- label: "StyledImage"
40
- })(process.env.NODE_ENV === "production" ? {
41
- name: "ie7djk",
42
- styles: "object-fit:cover;aspect-ratio:4/3"
43
- } : {
44
- name: "ie7djk",
45
- styles: "object-fit:cover;aspect-ratio:4/3",
46
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAgFiC","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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */",
47
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
- });
49
- const StyledResourceDescription = /*#__PURE__*/(0, _base.default)(_typography.Text, {
50
- target: "e18z2zfy2",
51
- label: "StyledResourceDescription"
52
- })("grid-area:description;line-clamp:2;height:3.1em;margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;", _core.mq.range({
53
- until: _core.breakpoints.mobileWide
54
- }), "{margin:0 ", _core.spacing.small, ";}overflow:hidden;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":"AAqF8C","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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */"));
55
- const TagsandActionMenu = /*#__PURE__*/(0, _base.default)("div", {
56
- target: "e18z2zfy1",
57
- label: "TagsandActionMenu"
58
- })("grid-area:tags;z-index:", _core.stackOrder.offsetSingle, ";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;", _core.mq.range({
59
- until: _core.breakpoints.mobileWide
60
- }), "{min-height:", _core.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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */"));
61
- const TopicAndTitleWrapper = /*#__PURE__*/(0, _base.default)("div", {
62
- target: "e18z2zfy0",
63
- label: "TopicAndTitleWrapper"
64
- })("grid-area:topicAndTitle;display:flex;margin:", _core.spacing.small, " 0;flex-direction:column;overflow:hidden;margin-right:", _core.spacing.small, ";", _core.mq.range({
65
- until: _core.breakpoints.mobileWide
66
- }), "{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\n/** @jsxImportSource @emotion/react */\nimport { ReactNode, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, colors, breakpoints, mq, stackOrder } from \"@ndla/core\";\nimport { Text } from \"@ndla/typography\";\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 Image from \"../Image\";\nimport { contentTypeMapping, MISSING, 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(Text)`\n  grid-area: description;\n  line-clamp: 2;\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  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: ${stackOrder.offsetSingle};\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    }\n    return (\n      <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === \"compact\" ? 56 : 136} />\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 (\n    <StyledResourceDescription element=\"p\" textStyle=\"meta-text-small\">\n      {description}\n    </StyledResourceDescription>\n  );\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  const contentType = useMemo(() => {\n    if (!firstContentType) {\n      return MISSING;\n    }\n    return contentTypeMapping[firstContentType] ?? embedResourceType ?? contentTypeMapping.default;\n  }, [embedResourceType, firstContentType]);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType} data-image-size={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          background={!!embedResourceType}\n          contentType={contentType}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink\n            to={link}\n            data-link=\"\"\n            target={targetBlank ? \"_blank\" : undefined}\n            data-resource-available={contentType !== MISSING}\n          >\n            <Text element=\"span\" textStyle=\"label-small\" css={resourceHeadingStyle} title={title}>\n              {title}\n            </Text>\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"]} */"));
67
- const ListResourceImage = _ref => {
68
- let {
69
- resourceImage,
70
- loading,
71
- type,
72
- contentType,
73
- background
74
- } = _ref;
75
- if (!loading) {
76
- if (resourceImage.src === "") {
77
- return (0, _jsxRuntime.jsx)(_resourceComponents.ContentIconWrapper, {
78
- contentType: contentType,
79
- children: (0, _jsxRuntime.jsx)(_ContentTypeBadge.default, {
80
- type: contentType,
81
- background: background,
82
- size: "x-small"
83
- })
84
- });
85
- }
86
- return (0, _jsxRuntime.jsx)(StyledImage, {
87
- alt: resourceImage.alt,
88
- src: resourceImage.src,
89
- fallbackWidth: type === "compact" ? 56 : 136
90
- });
91
- }
92
- return (0, _jsxRuntime.jsx)(_ContentLoader.default, {
93
- height: "100%",
94
- width: "100%",
95
- viewBox: null,
96
- preserveAspectRatio: "none",
97
- children: (0, _jsxRuntime.jsx)("rect", {
98
- x: "0",
99
- y: "0",
100
- rx: "3",
101
- ry: "3",
102
- width: type === "compact" ? "56" : "136",
103
- height: type === "compact" ? "40" : "96"
104
- })
105
- });
106
- };
107
- const TypeAndTitleLoader = _ref2 => {
108
- let {
109
- loading,
110
- children
111
- } = _ref2;
112
- if (loading) {
113
- return (0, _jsxRuntime.jsxs)(_ContentLoader.default, {
114
- height: "40px",
115
- width: "100%",
116
- viewBox: null,
117
- preserveAspectRatio: "none",
118
- children: [(0, _jsxRuntime.jsx)("rect", {
119
- x: "0",
120
- y: "0",
121
- rx: "3",
122
- ry: "3",
123
- width: "100%",
124
- height: "16"
125
- }), (0, _jsxRuntime.jsx)("rect", {
126
- x: "0",
127
- y: "18",
128
- rx: "3",
129
- ry: "3",
130
- width: "70",
131
- height: "16"
132
- }), (0, _jsxRuntime.jsx)("rect", {
133
- x: "80",
134
- y: "18",
135
- rx: "3",
136
- ry: "3",
137
- width: "70",
138
- height: "16"
139
- })]
140
- });
141
- }
142
- return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
143
- children: children
144
- });
145
- };
146
- const Description = _ref3 => {
147
- let {
148
- description,
149
- loading
150
- } = _ref3;
151
- if (loading) {
152
- return (0, _jsxRuntime.jsx)(_ContentLoader.default, {
153
- height: "20px",
154
- width: "100%",
155
- viewBox: null,
156
- preserveAspectRatio: "none",
157
- children: (0, _jsxRuntime.jsx)("rect", {
158
- x: "0",
159
- y: "0",
160
- width: "100%",
161
- height: "20"
162
- })
163
- });
164
- }
165
- return (0, _jsxRuntime.jsx)(StyledResourceDescription, {
166
- element: "p",
167
- textStyle: "meta-text-small",
168
- children: description
169
- });
170
- };
171
- const ListResource = _ref4 => {
172
- var _resourceTypes$0$id, _resourceTypes$;
173
- let {
174
- id,
175
- link,
176
- tagLinkPrefix,
177
- title,
178
- tags,
179
- resourceImage,
180
- resourceTypes,
181
- description,
182
- menu,
183
- isLoading = false,
184
- targetBlank
185
- } = _ref4;
186
- const showDescription = description !== undefined;
187
- const imageType = showDescription ? "normal" : "compact";
188
- const firstContentType = (_resourceTypes$0$id = resourceTypes === null || resourceTypes === void 0 || (_resourceTypes$ = resourceTypes[0]) === null || _resourceTypes$ === void 0 ? void 0 : _resourceTypes$.id) !== null && _resourceTypes$0$id !== void 0 ? _resourceTypes$0$id : "";
189
- const embedResourceType = _ContentType.resourceEmbedTypeMapping[firstContentType];
190
- const contentType = (0, _react.useMemo)(() => {
191
- var _ref5, _contentTypeMapping$f;
192
- if (!firstContentType) {
193
- return _ContentType.MISSING;
194
- }
195
- return (_ref5 = (_contentTypeMapping$f = _ContentType.contentTypeMapping[firstContentType]) !== null && _contentTypeMapping$f !== void 0 ? _contentTypeMapping$f : embedResourceType) !== null && _ref5 !== void 0 ? _ref5 : _ContentType.contentTypeMapping.default;
196
- }, [embedResourceType, firstContentType]);
197
- return (0, _jsxRuntime.jsxs)(ListResourceWrapper, {
198
- id: id,
199
- children: [(0, _jsxRuntime.jsx)(ImageWrapper, {
200
- imageSize: imageType,
201
- "data-image-size": imageType,
202
- children: (0, _jsxRuntime.jsx)(ListResourceImage, {
203
- resourceImage: resourceImage,
204
- loading: isLoading,
205
- type: imageType,
206
- background: !!embedResourceType,
207
- contentType: contentType
208
- })
209
- }), (0, _jsxRuntime.jsx)(TopicAndTitleWrapper, {
210
- children: (0, _jsxRuntime.jsxs)(TypeAndTitleLoader, {
211
- loading: isLoading,
212
- children: [(0, _jsxRuntime.jsx)(_resourceComponents.ResourceTitleLink, {
213
- to: link,
214
- "data-link": "",
215
- target: targetBlank ? "_blank" : undefined,
216
- "data-resource-available": contentType !== _ContentType.MISSING,
217
- children: (0, _jsxRuntime.jsx)(_typography.Text, {
218
- element: "span",
219
- textStyle: "label-small",
220
- css: _resourceComponents.resourceHeadingStyle,
221
- title: title,
222
- children: title
223
- })
224
- }), (0, _jsxRuntime.jsx)(_resourceComponents.ResourceTypeList, {
225
- resourceTypes: resourceTypes
226
- })]
227
- })
228
- }), showDescription && (0, _jsxRuntime.jsx)(Description, {
229
- description: description,
230
- loading: isLoading
231
- }), (0, _jsxRuntime.jsxs)(TagsandActionMenu, {
232
- children: [tags && tags.length > 0 && (0, _jsxRuntime.jsx)(_resourceComponents.CompressedTagList, {
233
- tagLinkPrefix: tagLinkPrefix,
234
- tags: tags
235
- }), menu]
236
- })]
237
- });
238
- };
239
- var _default = exports.default = ListResource;
@@ -1,11 +0,0 @@
1
- /**
2
- * Copyright (c) 2022-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
- import { ListResourceProps } from "./ListResource";
9
- export type { ListResourceProps };
10
- export { default as ListResource } from "./ListResource";
11
- export { default as BlockResource } from "./BlockResource";
@@ -1,20 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "BlockResource", {
7
- enumerable: true,
8
- get: function () {
9
- return _BlockResource.default;
10
- }
11
- });
12
- Object.defineProperty(exports, "ListResource", {
13
- enumerable: true,
14
- get: function () {
15
- return _ListResource.default;
16
- }
17
- });
18
- var _ListResource = _interopRequireDefault(require("./ListResource"));
19
- var _BlockResource = _interopRequireDefault(require("./BlockResource"));
20
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
@@ -1,43 +0,0 @@
1
- /**
2
- * Copyright (c) 2022-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
- import { HTMLAttributes, ReactNode } from "react";
9
- export interface ResourceImageProps {
10
- alt: string;
11
- src: string;
12
- }
13
- export declare const ResourceTitleLink: import("@emotion/styled").StyledComponent<Omit<import("@ndla/safelink").SafeLinkProps, "ref"> & import("react").RefAttributes<HTMLAnchorElement> & {
14
- theme?: import("@emotion/react").Theme | undefined;
15
- }, {}, {}>;
16
- export declare const resourceHeadingStyle: import("@emotion/utils").SerializedStyles;
17
- interface ContentIconProps extends HTMLAttributes<HTMLSpanElement> {
18
- contentType: string;
19
- children?: ReactNode;
20
- }
21
- export declare const ContentIconWrapper: ({ contentType, children, ...props }: ContentIconProps) => import("react/jsx-runtime").JSX.Element;
22
- interface TagListProps {
23
- tags?: string[];
24
- tagLinkPrefix?: string;
25
- }
26
- export interface LoaderProps {
27
- loading?: boolean;
28
- children?: ReactNode;
29
- }
30
- export declare const TagList: ({ tags, tagLinkPrefix }: TagListProps) => import("react/jsx-runtime").JSX.Element | null;
31
- interface CompressedTagListProps {
32
- tags: string[];
33
- tagLinkPrefix?: string;
34
- }
35
- export declare const CompressedTagList: ({ tags, tagLinkPrefix }: CompressedTagListProps) => import("react/jsx-runtime").JSX.Element;
36
- interface ResourceTypeListProps {
37
- resourceTypes?: {
38
- id: string;
39
- name: string;
40
- }[];
41
- }
42
- export declare const ResourceTypeList: ({ resourceTypes }: ResourceTypeListProps) => import("react/jsx-runtime").JSX.Element | null;
43
- export {};