@ndla/ui 55.0.14-alpha.0 → 55.0.15-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 (58) hide show
  1. package/dist/panda.buildinfo.json +22 -0
  2. package/dist/styles.css +86 -0
  3. package/es/Article/ArticleByline.js +7 -7
  4. package/es/AudioPlayer/AudioPlayer.js +1 -0
  5. package/es/Concept/Concept.js +2 -2
  6. package/es/ContactBlock/ContactBlock.js +17 -17
  7. package/es/Embed/BrightcoveEmbed.js +0 -1
  8. package/es/Embed/CopyrightEmbed.js +1 -2
  9. package/es/LicenseByline/EmbedByline.js +143 -33
  10. package/es/LicenseByline/LicenseLink.js +16 -9
  11. package/es/LicenseByline/index.js +2 -2
  12. package/es/index.js +0 -1
  13. package/es/styles.css +86 -0
  14. package/lib/Article/ArticleByline.js +8 -8
  15. package/lib/AudioPlayer/AudioPlayer.js +1 -0
  16. package/lib/Concept/Concept.js +1 -1
  17. package/lib/ContactBlock/ContactBlock.js +18 -18
  18. package/lib/Embed/BrightcoveEmbed.js +0 -1
  19. package/lib/Embed/CopyrightEmbed.js +1 -2
  20. package/lib/LicenseByline/EmbedByline.d.ts +2 -4
  21. package/lib/LicenseByline/EmbedByline.js +145 -35
  22. package/lib/LicenseByline/LicenseLink.d.ts +2 -2
  23. package/lib/LicenseByline/LicenseLink.js +16 -9
  24. package/lib/LicenseByline/index.d.ts +2 -2
  25. package/lib/LicenseByline/index.js +4 -5
  26. package/lib/index.d.ts +0 -1
  27. package/lib/index.js +0 -13
  28. package/lib/styles.css +86 -0
  29. package/package.json +5 -5
  30. package/src/Article/ArticleByline.tsx +1 -1
  31. package/src/AudioPlayer/AudioPlayer.tsx +1 -0
  32. package/src/Concept/Concept.tsx +2 -2
  33. package/src/ContactBlock/ContactBlock.tsx +1 -1
  34. package/src/Embed/BrightcoveEmbed.tsx +1 -1
  35. package/src/Embed/CopyrightEmbed.tsx +1 -1
  36. package/src/LicenseByline/EmbedByline.stories.tsx +9 -4
  37. package/src/LicenseByline/EmbedByline.tsx +139 -53
  38. package/src/LicenseByline/LicenseLink.tsx +15 -15
  39. package/src/LicenseByline/index.tsx +2 -2
  40. package/src/index.ts +0 -1
  41. package/es/LicenseByline/LicenseDescription.js +0 -63
  42. package/es/List/OrderedList.js +0 -41
  43. package/es/List/UnOrderedList.js +0 -28
  44. package/es/List/index.js +0 -10
  45. package/lib/LicenseByline/LicenseDescription.d.ts +0 -15
  46. package/lib/LicenseByline/LicenseDescription.js +0 -70
  47. package/lib/List/OrderedList.d.ts +0 -16
  48. package/lib/List/OrderedList.js +0 -48
  49. package/lib/List/UnOrderedList.d.ts +0 -10
  50. package/lib/List/UnOrderedList.js +0 -35
  51. package/lib/List/index.d.ts +0 -9
  52. package/lib/List/index.js +0 -20
  53. package/src/LicenseByline/LicenseDescription.tsx +0 -100
  54. package/src/List/OrderedList.stories.tsx +0 -135
  55. package/src/List/OrderedList.tsx +0 -158
  56. package/src/List/UnOrderedList.tsx +0 -43
  57. package/src/List/UnorderedList.stories.tsx +0 -72
  58. package/src/List/index.ts +0 -10
@@ -17,7 +17,7 @@ import { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from
17
17
  import { COPYRIGHTED, getLicenseByAbbreviation } from "@ndla/licenses";
18
18
  import { Image } from "@ndla/primitives";
19
19
  import { errorSvgSrc } from "../Embed/ImageEmbed";
20
- import LicenseLink from "../LicenseByline/LicenseLink";
20
+ import { LicenseLink } from "../LicenseByline/LicenseLink";
21
21
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
22
22
  const BLOB_WIDTH = 90;
23
23
  const BlockWrapper = /*#__PURE__*/_styled("div", {
@@ -25,29 +25,29 @@ const BlockWrapper = /*#__PURE__*/_styled("div", {
25
25
  label: "BlockWrapper"
26
26
  })("display:flex;position:relative;flex-direction:column;padding:0 0 ", spacing.medium, " ", spacing.medium, ";font-family:", fonts.sans, ";border-radius:", misc.borderRadius, ";border:1px solid ", colors.brand.lighter, ";background-color:", colors.white, ";&~&{margin-top:", spacing.medium, ";}", mq.range({
27
27
  from: breakpoints.tablet
28
- }), "{max-width:773px;flex-direction:row;padding:0 0 ", spacing.medium, " ", spacing.medium, ";gap:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAqC+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
28
+ }), "{max-width:773px;flex-direction:row;padding:0 0 ", spacing.medium, " ", spacing.medium, ";gap:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAqC+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
29
29
  const StyledHeader = /*#__PURE__*/_styled("div", {
30
30
  target: "eaumufc13",
31
31
  label: "StyledHeader"
32
- })(fonts.sizes("22px", "30px"), ";font-weight:", fonts.weight.bold, ";margin:0 0 ", spacing.xsmall, " 0;padding-top:", spacing.medium, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAyD+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
32
+ })(fonts.sizes("22px", "30px"), ";font-weight:", fonts.weight.bold, ";margin:0 0 ", spacing.xsmall, " 0;padding-top:", spacing.medium, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAyD+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
33
33
  const StyledText = /*#__PURE__*/_styled("div", {
34
34
  target: "eaumufc12",
35
35
  label: "StyledText"
36
- })("display:flex;", fonts.sizes("16px", "26px"), ";overflow-wrap:anywhere;color:", colors.text.light, ";gap:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgE6B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
36
+ })("display:flex;", fonts.sizes("16px", "26px"), ";overflow-wrap:anywhere;color:", colors.text.light, ";gap:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgE6B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
37
37
  const EmailLink = /*#__PURE__*/_styled("a", {
38
38
  target: "eaumufc11",
39
39
  label: "EmailLink"
40
- })("color:", colors.text.light, ";text-decoration-color:", colors.text.light, ";text-decoration-style:solid;text-decoration:underline;box-shadow:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAwE0B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
40
+ })("color:", colors.text.light, ";text-decoration-color:", colors.text.light, ";text-decoration-style:solid;text-decoration:underline;box-shadow:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAwE0B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
41
41
  const SummaryBlock = /*#__PURE__*/_styled("p", {
42
42
  target: "eaumufc10",
43
43
  label: "SummaryBlock"
44
44
  })("font-family:", fonts.sans, ";padding:0;max-width:calc(100% - (", BLOB_WIDTH, "px / 2));", mq.range({
45
45
  from: breakpoints.tabletWide
46
- }), "{padding-top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgF6B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
46
+ }), "{padding-top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgF6B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
47
47
  const InfoWrapper = /*#__PURE__*/_styled("div", {
48
48
  target: "eaumufc9",
49
49
  label: "InfoWrapper"
50
- })("max-width:calc(100% - ", BLOB_WIDTH, "px);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAyF8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
50
+ })("max-width:calc(100% - ", BLOB_WIDTH, "px);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAyF8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
51
51
  const TextWrapper = /*#__PURE__*/_styled("div", {
52
52
  target: "eaumufc8",
53
53
  label: "TextWrapper"
@@ -57,28 +57,28 @@ const TextWrapper = /*#__PURE__*/_styled("div", {
57
57
  } : {
58
58
  name: "1mtmrfr",
59
59
  styles: "display:flex;overflow:hidden;justify-content:space-between",
60
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA6F8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
60
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA6F8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
61
61
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
62
62
  });
63
63
  const BlobWrapper = /*#__PURE__*/_styled("div", {
64
64
  target: "eaumufc7",
65
65
  label: "BlobWrapper"
66
- })("height:180px;width:", BLOB_WIDTH, "px;position:absolute;overflow:hidden;right:0px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAmG8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
66
+ })("height:180px;width:", BLOB_WIDTH, "px;position:absolute;overflow:hidden;right:0px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAmG8B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
67
67
  const ImageWrapper = /*#__PURE__*/_styled("div", {
68
68
  target: "eaumufc6",
69
69
  label: "ImageWrapper"
70
70
  })("display:flex;flex-direction:column;gap:", spacing.xsmall, ";", fonts.sizes("16px", "26px"), ";padding:", spacing.medium, " ", spacing.medium, " 0 0;", mq.range({
71
71
  from: breakpoints.tablet
72
- }), "{padding-right:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA2G+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
73
- const blobStyling = /*#__PURE__*/css("width:165px;height:180px;transform:translate(10%, 0);color:", colors.support.redLight, ";&[data-green=\"true\"]{color:", colors.support.greenLight, ";};label:blobStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAsHuB","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
72
+ }), "{padding-right:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA2G+B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
73
+ const blobStyling = /*#__PURE__*/css("width:165px;height:180px;transform:translate(10%, 0);color:", colors.support.redLight, ";&[data-green=\"true\"]{color:", colors.support.greenLight, ";};label:blobStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAsHuB","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
74
74
  const BlobPointy = /*#__PURE__*/_styled(UnstyledBlobPointy, {
75
75
  target: "eaumufc5",
76
76
  label: "BlobPointy"
77
- })(blobStyling, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgI6C","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
77
+ })(blobStyling, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAgI6C","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
78
78
  const BlobRound = /*#__PURE__*/_styled(UnstyledBlobRound, {
79
79
  target: "eaumufc4",
80
80
  label: "BlobRound"
81
- })(blobStyling, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAoI2C","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
81
+ })(blobStyling, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAoI2C","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
82
82
  const Email = /*#__PURE__*/_styled("div", {
83
83
  target: "eaumufc3",
84
84
  label: "Email"
@@ -88,7 +88,7 @@ const Email = /*#__PURE__*/_styled("div", {
88
88
  } : {
89
89
  name: "1bmnxg7",
90
90
  styles: "white-space:nowrap",
91
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAuIwB","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
91
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAuIwB","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
92
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
93
  });
94
94
  const ContentWrapper = /*#__PURE__*/_styled("div", {
@@ -100,7 +100,7 @@ const ContentWrapper = /*#__PURE__*/_styled("div", {
100
100
  } : {
101
101
  name: "1d3w5wq",
102
102
  styles: "width:100%",
103
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA2IiC","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
103
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA2IiC","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
104
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
105
105
  });
106
106
  const StyledImage = /*#__PURE__*/_styled(Image, {
@@ -112,7 +112,7 @@ const StyledImage = /*#__PURE__*/_styled(Image, {
112
112
  } : {
113
113
  name: "1vfhcql",
114
114
  styles: "object-fit:cover",
115
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA+IiC","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
115
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA+IiC","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
116
116
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
117
117
  });
118
118
  const StyledLink = /*#__PURE__*/_styled("a", {
@@ -124,7 +124,7 @@ const StyledLink = /*#__PURE__*/_styled("a", {
124
124
  } : {
125
125
  name: "g65o95",
126
126
  styles: "text-decoration:none",
127
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAwJ2B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport LicenseLink from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
127
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAwJ2B","file":"ContactBlock.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { spacing, fonts, colors, mq, breakpoints, misc } from \"@ndla/core\";\nimport { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from \"@ndla/icons/common\";\nimport { COPYRIGHTED, getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport { Image } from \"@ndla/primitives\";\nimport { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\n\nconst BLOB_WIDTH = 90;\n\ninterface Props {\n  image?: IImageMetaInformationV3;\n  jobTitle: string;\n  description: string;\n  blobColor?: \"pink\" | \"green\";\n  blob?: \"pointy\" | \"round\";\n  imageWidth?: number;\n  name: string;\n  email: string;\n  embedAlt?: string;\n  lang?: string;\n  imageCanonicalUrl?: CanonicalUrlFuncs[\"image\"];\n}\nconst BlockWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  padding: 0 0 ${spacing.medium} ${spacing.medium};\n  font-family: ${fonts.sans};\n  border-radius: ${misc.borderRadius};\n  border: 1px solid ${colors.brand.lighter};\n  background-color: ${colors.white};\n  & ~ & {\n    margin-top: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 773px;\n    flex-direction: row;\n    padding: 0 0 ${spacing.medium} ${spacing.medium};\n    gap: ${spacing.nsmall};\n  }\n`;\n\nconst StyledHeader = styled.div`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  font-weight: ${fonts.weight.bold};\n  margin: 0 0 ${spacing.xsmall} 0;\n  padding-top: ${spacing.medium};\n`;\n\nconst StyledText = styled.div`\n  display: flex;\n  ${fonts.sizes(\"16px\", \"26px\")};\n  overflow-wrap: anywhere;\n  color: ${colors.text.light};\n  gap: ${spacing.xxsmall};\n`;\n\nconst EmailLink = styled.a`\n  color: ${colors.text.light};\n  text-decoration-color: ${colors.text.light};\n  text-decoration-style: solid;\n  text-decoration: underline;\n  box-shadow: unset;\n`;\n\nconst SummaryBlock = styled.p`\n  font-family: ${fonts.sans};\n  padding: 0;\n  max-width: calc(100% - (${BLOB_WIDTH}px / 2));\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 0;\n  }\n`;\n\nconst InfoWrapper = styled.div`\n  max-width: calc(100% - ${BLOB_WIDTH}px);\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  overflow: hidden;\n  justify-content: space-between;\n`;\n\nconst BlobWrapper = styled.div`\n  height: 180px;\n  width: ${BLOB_WIDTH}px;\n  position: absolute;\n  overflow: hidden;\n  right: 0px;\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.xsmall};\n  ${fonts.sizes(\"16px\", \"26px\")};\n  padding: ${spacing.medium} ${spacing.medium} 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: 0;\n  }\n`;\n\nconst blobStyling = css`\n  width: 165px;\n  height: 180px;\n  transform: translate(10%, 0);\n  color: ${colors.support.redLight};\n  &[data-green=\"true\"] {\n    color: ${colors.support.greenLight};\n  }\n`;\n\nconst BlobPointy = styled(UnstyledBlobPointy)`\n  ${blobStyling}\n`;\n\nconst BlobRound = styled(UnstyledBlobRound)`\n  ${blobStyling}\n`;\nconst Email = styled.div`\n  white-space: nowrap;\n`;\n\nconst ContentWrapper = styled.div`\n  width: 100%;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n`;\n\ninterface LinkWrapperProps {\n  src?: string;\n  children: ReactNode;\n}\n\nconst StyledLink = styled.a`\n  text-decoration: none;\n`;\n\nconst LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return (\n      <StyledLink target=\"_blank\" href={src} rel=\"noopener noreferrer\">\n        {children}\n      </StyledLink>\n    );\n  }\n  return children;\n};\n\nconst ContactBlock = ({\n  image,\n  jobTitle,\n  description,\n  name,\n  email,\n  embedAlt,\n  blobColor = \"green\",\n  blob = \"pointy\",\n  imageCanonicalUrl,\n  lang,\n}: Props) => {\n  const { t, i18n } = useTranslation();\n  const isGreenBlob = blobColor === \"green\";\n  const Blob = blob === \"pointy\" ? BlobPointy : BlobRound;\n  const authors = [image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders]\n    .filter((authors) => !!authors?.length)\n    .reduce<IAuthor[]>((acc, val) => acc.concat(val!), []);\n  const license = image?.copyright\n    ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)\n    : undefined;\n\n  const isCopyrighted = image?.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <BlockWrapper>\n      <ImageWrapper>\n        {image ? (\n          <>\n            <LinkWrapper src={!isCopyrighted && image ? imageCanonicalUrl?.(image) : undefined}>\n              <StyledImage\n                alt={embedAlt !== undefined ? embedAlt : image.alttext.alttext}\n                src={image.image.imageUrl}\n                sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}\n              />\n            </LinkWrapper>\n            <span>\n              {`${t(\"embed.type.image\")}: ${authors.map((author) => `${author?.name}`).join(\", \")} `}\n              {!!license && <LicenseLink license={license} />}\n            </span>\n          </>\n        ) : (\n          <img alt={t(\"image.error.url\")} src={errorSvgSrc} />\n        )}\n      </ImageWrapper>\n      <ContentWrapper>\n        <TextWrapper>\n          <InfoWrapper>\n            <StyledHeader lang={lang}>{name}</StyledHeader>\n            <StyledText lang={lang}>{jobTitle}</StyledText>\n            <StyledText>\n              <Email>{`${t(\"email\")}:`}</Email>\n              <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\n            </StyledText>\n          </InfoWrapper>\n          <BlobWrapper>\n            <Blob data-green={isGreenBlob} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
128
128
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
129
129
  });
130
130
  const LinkWrapper = _ref => {