@ndla/ui 55.0.5-alpha.0 → 55.0.8-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.
- package/es/ContactBlock/ContactBlock.js +31 -24
- package/es/Embed/ImageEmbed.js +3 -3
- package/es/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/es/Figure/index.js +1 -2
- package/es/Notion/NotionImage.js +15 -10
- package/es/Search/ContentTypeResult.js +3 -3
- package/es/Search/SearchResultSleeve.js +11 -11
- package/es/Table/Table.js +16 -13
- package/lib/ContactBlock/ContactBlock.js +31 -24
- package/lib/Embed/ImageEmbed.js +3 -3
- package/lib/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/lib/Figure/index.d.ts +0 -1
- package/lib/Figure/index.js +0 -7
- package/lib/Notion/NotionImage.d.ts +5 -0
- package/lib/Notion/NotionImage.js +14 -9
- package/lib/Search/ContentTypeResult.js +3 -3
- package/lib/Search/SearchResultSleeve.js +11 -11
- package/lib/Table/Table.js +16 -13
- package/package.json +9 -9
- package/src/ContactBlock/ContactBlock.tsx +10 -2
- package/src/Embed/ImageEmbed.tsx +7 -5
- package/src/ErrorMessage/ErrorResourceAccessDenied.tsx +2 -2
- package/src/Figure/index.ts +0 -1
- package/src/Notion/NotionImage.tsx +33 -8
- package/src/Search/ContentTypeResult.tsx +2 -2
- package/src/Search/SearchResultSleeve.tsx +3 -3
- package/src/Table/Table.tsx +6 -2
- package/es/Figure/figureActionIndicatorStyle.js +0 -13
- package/lib/Figure/figureActionIndicatorStyle.d.ts +0 -8
- package/lib/Figure/figureActionIndicatorStyle.js +0 -19
- package/src/Figure/figureActionIndicatorStyle.ts +0 -39
|
@@ -13,7 +13,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
|
|
|
13
13
|
import { useTranslation } from "react-i18next";
|
|
14
14
|
import { css } from "@emotion/react";
|
|
15
15
|
import { spacing, fonts, colors, mq, breakpoints, misc } from "@ndla/core";
|
|
16
|
-
import { BlobPointy, BlobRound } from "@ndla/icons/common";
|
|
16
|
+
import { BlobPointy as UnstyledBlobPointy, BlobRound as UnstyledBlobRound } from "@ndla/icons/common";
|
|
17
17
|
import { COPYRIGHTED, getLicenseByAbbreviation } from "@ndla/licenses";
|
|
18
18
|
import { errorSvgSrc } from "../Embed/ImageEmbed";
|
|
19
19
|
import Image, { ImageLink } from "../Image";
|
|
@@ -21,35 +21,35 @@ 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", {
|
|
24
|
-
target: "
|
|
24
|
+
target: "eaumufc13",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
30
|
+
target: "eaumufc12",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
34
|
+
target: "eaumufc11",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
38
|
+
target: "eaumufc10",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
42
|
+
target: "eaumufc9",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
48
|
+
target: "eaumufc8",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
52
|
+
target: "eaumufc7",
|
|
53
53
|
label: "TextWrapper"
|
|
54
54
|
})(process.env.NODE_ENV === "production" ? {
|
|
55
55
|
name: "1mtmrfr",
|
|
@@ -57,20 +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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
64
|
+
target: "eaumufc6",
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
-
target: "
|
|
68
|
+
target: "eaumufc5",
|
|
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,
|
|
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,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
+
const BlobPointy = /*#__PURE__*/_styled(UnstyledBlobPointy, {
|
|
75
|
+
target: "eaumufc4",
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
|
+
const BlobRound = /*#__PURE__*/_styled(UnstyledBlobRound, {
|
|
79
|
+
target: "eaumufc3",
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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
82
|
const Email = /*#__PURE__*/_styled("div", {
|
|
75
83
|
target: "eaumufc2",
|
|
76
84
|
label: "Email"
|
|
@@ -80,7 +88,7 @@ const Email = /*#__PURE__*/_styled("div", {
|
|
|
80
88
|
} : {
|
|
81
89
|
name: "1bmnxg7",
|
|
82
90
|
styles: "white-space:nowrap",
|
|
83
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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"]} */",
|
|
84
92
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
85
93
|
});
|
|
86
94
|
const ContentWrapper = /*#__PURE__*/_styled("div", {
|
|
@@ -92,7 +100,7 @@ const ContentWrapper = /*#__PURE__*/_styled("div", {
|
|
|
92
100
|
} : {
|
|
93
101
|
name: "1d3w5wq",
|
|
94
102
|
styles: "width:100%",
|
|
95
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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"]} */",
|
|
96
104
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
97
105
|
});
|
|
98
106
|
const StyledImage = /*#__PURE__*/_styled(Image, {
|
|
@@ -104,7 +112,7 @@ const StyledImage = /*#__PURE__*/_styled(Image, {
|
|
|
104
112
|
} : {
|
|
105
113
|
name: "1vfhcql",
|
|
106
114
|
styles: "object-fit:cover",
|
|
107
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 { IAuthor, IImageMetaInformationV3 } from \"@ndla/types-backend/image-api\";\nimport { CanonicalUrlFuncs } from \"../Embed\";\nimport { errorSvgSrc } from \"../Embed/ImageEmbed\";\nimport Image, { ImageLink } from \"../Image\";\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 LinkWrapper = ({ src, children }: LinkWrapperProps) => {\n  if (src) {\n    return <ImageLink src={src}>{children}</ImageLink>;\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"]} */",
|
|
108
116
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
109
117
|
});
|
|
110
118
|
const LinkWrapper = _ref => {
|
|
@@ -180,7 +188,6 @@ const ContactBlock = _ref2 => {
|
|
|
180
188
|
})]
|
|
181
189
|
}), _jsx(BlobWrapper, {
|
|
182
190
|
children: _jsx(Blob, {
|
|
183
|
-
css: blobStyling,
|
|
184
191
|
"data-green": isGreenBlob
|
|
185
192
|
})
|
|
186
193
|
})]
|