@ndla/ui 49.0.6 → 49.0.7
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 +47 -31
- package/es/Embed/ImageEmbed.js +3 -2
- package/lib/ContactBlock/ContactBlock.d.ts +3 -1
- package/lib/ContactBlock/ContactBlock.js +49 -30
- package/lib/Embed/ImageEmbed.d.ts +3 -2
- package/lib/Embed/ImageEmbed.js +3 -2
- package/lib/Embed/index.d.ts +1 -1
- package/lib/Embed/types.d.ts +8 -0
- package/lib/index.d.ts +1 -1
- package/package.json +17 -17
- package/src/ContactBlock/ContactBlock.tsx +27 -7
- package/src/Embed/ImageEmbed.tsx +4 -2
- package/src/Embed/index.ts +1 -1
- package/src/Embed/types.ts +9 -0
- package/src/index.ts +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
@@ -12,9 +13,11 @@ var _core = require("@ndla/core");
|
|
|
12
13
|
var _common = require("@ndla/icons/common");
|
|
13
14
|
var _licenses = require("@ndla/licenses");
|
|
14
15
|
var _ImageEmbed = require("../Embed/ImageEmbed");
|
|
15
|
-
var _Image =
|
|
16
|
+
var _Image = _interopRequireWildcard(require("../Image"));
|
|
16
17
|
var _LicenseLink = _interopRequireDefault(require("../LicenseByline/LicenseLink"));
|
|
17
18
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
19
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
20
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
18
21
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
22
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /**
|
|
20
23
|
* Copyright (c) 2023-present, NDLA.
|
|
@@ -29,29 +32,29 @@ var BlockWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
29
32
|
label: "BlockWrapper"
|
|
30
33
|
})("display:flex;position:relative;flex-direction:column;padding:0 0 ", _core.spacing.medium, " ", _core.spacing.medium, ";font-family:", _core.fonts.sans, ";border-radius:", _core.misc.borderRadius, ";border:1px solid ", _core.colors.brand.lighter, ";background-color:", _core.colors.white, ";&~&{margin-top:", _core.spacing.medium, ";}", _core.mq.range({
|
|
31
34
|
from: _core.breakpoints.tablet
|
|
32
|
-
}), "{max-width:773px;flex-direction:row;padding:0 0 ", _core.spacing.medium, " ", _core.spacing.medium, ";gap:", _core.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
35
|
+
}), "{max-width:773px;flex-direction:row;padding:0 0 ", _core.spacing.medium, " ", _core.spacing.medium, ";gap:", _core.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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
33
36
|
var StyledHeader = /*#__PURE__*/(0, _base.default)("div", {
|
|
34
37
|
target: "eaumufc10",
|
|
35
38
|
label: "StyledHeader"
|
|
36
|
-
})(_core.fonts.sizes('22px', '30px'), ";font-weight:", _core.fonts.weight.bold, ";margin:0 0 ", _core.spacing.xsmall, " 0;padding-top:", _core.spacing.medium, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
39
|
+
})(_core.fonts.sizes('22px', '30px'), ";font-weight:", _core.fonts.weight.bold, ";margin:0 0 ", _core.spacing.xsmall, " 0;padding-top:", _core.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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
37
40
|
var StyledText = /*#__PURE__*/(0, _base.default)("div", {
|
|
38
41
|
target: "eaumufc9",
|
|
39
42
|
label: "StyledText"
|
|
40
|
-
})("display:flex;", _core.fonts.sizes('16px', '26px'), ";overflow-wrap:anywhere;color:", _core.colors.text.light, ";gap:", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43
|
+
})("display:flex;", _core.fonts.sizes('16px', '26px'), ";overflow-wrap:anywhere;color:", _core.colors.text.light, ";gap:", _core.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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
41
44
|
var EmailLink = /*#__PURE__*/(0, _base.default)("a", {
|
|
42
45
|
target: "eaumufc8",
|
|
43
46
|
label: "EmailLink"
|
|
44
|
-
})("color:", _core.colors.text.light, ";text-decoration-color:", _core.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,
|
|
47
|
+
})("color:", _core.colors.text.light, ";text-decoration-color:", _core.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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
45
48
|
var SummaryBlock = /*#__PURE__*/(0, _base.default)("p", {
|
|
46
49
|
target: "eaumufc7",
|
|
47
50
|
label: "SummaryBlock"
|
|
48
51
|
})("font-family:", _core.fonts.sans, ";padding:0;max-width:calc(100% - (", BLOB_WIDTH, "px / 2));", _core.mq.range({
|
|
49
52
|
from: _core.breakpoints.tabletWide
|
|
50
|
-
}), "{padding-top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
53
|
+
}), "{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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
51
54
|
var InfoWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
52
55
|
target: "eaumufc6",
|
|
53
56
|
label: "InfoWrapper"
|
|
54
|
-
})("max-width:calc(100% - ", BLOB_WIDTH, "px);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
57
|
+
})("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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
55
58
|
var TextWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
56
59
|
target: "eaumufc5",
|
|
57
60
|
label: "TextWrapper"
|
|
@@ -61,26 +64,26 @@ var TextWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
61
64
|
} : {
|
|
62
65
|
name: "1mtmrfr",
|
|
63
66
|
styles: "display:flex;overflow:hidden;justify-content:space-between",
|
|
64
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
67
|
+
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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
|
|
65
68
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
66
69
|
});
|
|
67
70
|
var BlobWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
68
71
|
target: "eaumufc4",
|
|
69
72
|
label: "BlobWrapper"
|
|
70
|
-
})("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,
|
|
73
|
+
})("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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
71
74
|
var ImageWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
72
75
|
target: "eaumufc3",
|
|
73
76
|
label: "ImageWrapper"
|
|
74
77
|
})("display:flex;flex-direction:column;gap:", _core.spacing.xsmall, ";", _core.fonts.sizes('16px', '26px'), ";padding:", _core.spacing.medium, " ", _core.spacing.medium, " 0 0;", _core.mq.range({
|
|
75
78
|
from: _core.breakpoints.tablet
|
|
76
|
-
}), "{padding-right:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
79
|
+
}), "{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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */"));
|
|
77
80
|
var blobStyling = process.env.NODE_ENV === "production" ? {
|
|
78
81
|
name: "kz9ira-blobStyling",
|
|
79
82
|
styles: "width:165px;height:180px;transform:translate(10%, 0);label:blobStyling;"
|
|
80
83
|
} : {
|
|
81
84
|
name: "kz9ira-blobStyling",
|
|
82
85
|
styles: "width:165px;height:180px;transform:translate(10%, 0);label:blobStyling;",
|
|
83
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
86
|
+
map: "/*# 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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
|
|
84
87
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
85
88
|
};
|
|
86
89
|
var Email = /*#__PURE__*/(0, _base.default)("div", {
|
|
@@ -92,7 +95,7 @@ var Email = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
92
95
|
} : {
|
|
93
96
|
name: "1bmnxg7",
|
|
94
97
|
styles: "white-space:nowrap",
|
|
95
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
98
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA2HwB","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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
|
|
96
99
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
97
100
|
});
|
|
98
101
|
var ContentWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
@@ -104,7 +107,7 @@ var ContentWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
104
107
|
} : {
|
|
105
108
|
name: "1d3w5wq",
|
|
106
109
|
styles: "width:100%",
|
|
107
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
110
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AA+HiC","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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
|
|
108
111
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
109
112
|
});
|
|
110
113
|
var StyledImage = /*#__PURE__*/(0, _base.default)(_Image.default, {
|
|
@@ -116,21 +119,33 @@ var StyledImage = /*#__PURE__*/(0, _base.default)(_Image.default, {
|
|
|
116
119
|
} : {
|
|
117
120
|
name: "1vfhcql",
|
|
118
121
|
styles: "object-fit:cover",
|
|
119
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
122
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContactBlock.tsx"],"names":[],"mappings":"AAmIiC","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\nimport { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport concat from 'lodash/concat';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';\nimport { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';\nimport { BlobPointy, BlobRound } from '@ndla/icons/common';\nimport { COPYRIGHTED, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { errorSvgSrc } from '../Embed/ImageEmbed';\nimport Image, { ImageLink } from '../Image';\nimport LicenseLink from '../LicenseByline/LicenseLink';\nimport { CanonicalUrlFuncs } from '../Embed';\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`;\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 = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);\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('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}\n              {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}\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 css={blobStyling} color={isGreenBlob ? colors.support.greenLight : colors.support.redLight} />\n          </BlobWrapper>\n        </TextWrapper>\n        <SummaryBlock>{description}</SummaryBlock>\n      </ContentWrapper>\n    </BlockWrapper>\n  );\n};\n\nexport default ContactBlock;\n"]} */",
|
|
120
123
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
121
124
|
});
|
|
122
|
-
var
|
|
123
|
-
var
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
125
|
+
var LinkWrapper = function LinkWrapper(_ref) {
|
|
126
|
+
var src = _ref.src,
|
|
127
|
+
children = _ref.children;
|
|
128
|
+
if (src) {
|
|
129
|
+
return (0, _jsxRuntime.jsx)(_Image.ImageLink, {
|
|
130
|
+
src: src,
|
|
131
|
+
children: children
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
return children;
|
|
135
|
+
};
|
|
136
|
+
var ContactBlock = function ContactBlock(_ref2) {
|
|
137
|
+
var image = _ref2.image,
|
|
138
|
+
jobTitle = _ref2.jobTitle,
|
|
139
|
+
description = _ref2.description,
|
|
140
|
+
name = _ref2.name,
|
|
141
|
+
email = _ref2.email,
|
|
142
|
+
embedAlt = _ref2.embedAlt,
|
|
143
|
+
_ref2$blobColor = _ref2.blobColor,
|
|
144
|
+
blobColor = _ref2$blobColor === void 0 ? 'green' : _ref2$blobColor,
|
|
145
|
+
_ref2$blob = _ref2.blob,
|
|
146
|
+
blob = _ref2$blob === void 0 ? 'pointy' : _ref2$blob,
|
|
147
|
+
imageCanonicalUrl = _ref2.imageCanonicalUrl,
|
|
148
|
+
lang = _ref2.lang;
|
|
134
149
|
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
135
150
|
t = _useTranslation.t,
|
|
136
151
|
i18n = _useTranslation.i18n;
|
|
@@ -138,13 +153,17 @@ var ContactBlock = function ContactBlock(_ref) {
|
|
|
138
153
|
var Blob = blob === 'pointy' ? _common.BlobPointy : _common.BlobRound;
|
|
139
154
|
var authors = (0, _concat.default)(image === null || image === void 0 ? void 0 : image.copyright.processors, image === null || image === void 0 ? void 0 : image.copyright.creators, image === null || image === void 0 ? void 0 : image.copyright.rightsholders);
|
|
140
155
|
var license = image !== null && image !== void 0 && image.copyright ? (0, _licenses.getLicenseByAbbreviation)(image.copyright.license.license, i18n.language) : undefined;
|
|
156
|
+
var isCopyrighted = (image === null || image === void 0 ? void 0 : image.copyright.license.license.toLowerCase()) === _licenses.COPYRIGHTED;
|
|
141
157
|
return (0, _jsxRuntime.jsxs)(BlockWrapper, {
|
|
142
158
|
children: [(0, _jsxRuntime.jsx)(ImageWrapper, {
|
|
143
159
|
children: image ? (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
144
|
-
children: [(0, _jsxRuntime.jsx)(
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
160
|
+
children: [(0, _jsxRuntime.jsx)(LinkWrapper, {
|
|
161
|
+
src: !isCopyrighted && image ? imageCanonicalUrl === null || imageCanonicalUrl === void 0 ? void 0 : imageCanonicalUrl(image) : undefined,
|
|
162
|
+
children: (0, _jsxRuntime.jsx)(StyledImage, {
|
|
163
|
+
alt: embedAlt !== undefined ? embedAlt : image.alttext.alttext,
|
|
164
|
+
src: image.image.imageUrl,
|
|
165
|
+
sizes: "(min-width: ".concat(_core.breakpoints.tablet, ") 240px, (max-width: ").concat(_core.breakpoints.tablet, ") 500px")
|
|
166
|
+
})
|
|
148
167
|
}), (0, _jsxRuntime.jsxs)("span", {
|
|
149
168
|
children: ["".concat(t('photo'), ": ").concat(authors.reduce(function (acc, name) {
|
|
150
169
|
return acc = "".concat(acc, " ").concat(name === null || name === void 0 ? void 0 : name.name);
|