@ndla/ui 54.0.6 → 55.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/es/ContactBlock/ContactBlock.js +14 -15
  2. package/es/Embed/AudioEmbed.js +1 -32
  3. package/es/Embed/BrightcoveEmbed.js +6 -10
  4. package/es/Embed/ConceptEmbed.js +8 -33
  5. package/es/Embed/ImageEmbed.js +36 -79
  6. package/es/Embed/UuDisclaimerEmbed.js +4 -12
  7. package/es/Embed/conceptComponents.js +28 -29
  8. package/es/LicenseByline/EmbedByline.js +44 -61
  9. package/es/LicenseByline/LicenseDescription.js +44 -8
  10. package/es/LicenseByline/LicenseLink.js +7 -11
  11. package/es/Messages/MessageBox.js +6 -6
  12. package/es/index.js +1 -2
  13. package/es/locale/messages-en.js +33 -21
  14. package/es/locale/messages-nb.js +33 -21
  15. package/es/locale/messages-nn.js +32 -20
  16. package/es/locale/messages-se.js +34 -22
  17. package/es/locale/messages-sma.js +33 -21
  18. package/lib/ContactBlock/ContactBlock.js +14 -15
  19. package/lib/Embed/AudioEmbed.d.ts +1 -3
  20. package/lib/Embed/AudioEmbed.js +1 -32
  21. package/lib/Embed/BrightcoveEmbed.d.ts +2 -3
  22. package/lib/Embed/BrightcoveEmbed.js +6 -10
  23. package/lib/Embed/ConceptEmbed.d.ts +4 -9
  24. package/lib/Embed/ConceptEmbed.js +8 -33
  25. package/lib/Embed/ImageEmbed.d.ts +2 -5
  26. package/lib/Embed/ImageEmbed.js +34 -79
  27. package/lib/Embed/UuDisclaimerEmbed.js +3 -11
  28. package/lib/Embed/conceptComponents.d.ts +0 -3
  29. package/lib/Embed/conceptComponents.js +28 -29
  30. package/lib/LicenseByline/EmbedByline.d.ts +7 -6
  31. package/lib/LicenseByline/EmbedByline.js +46 -60
  32. package/lib/LicenseByline/LicenseDescription.d.ts +3 -2
  33. package/lib/LicenseByline/LicenseDescription.js +43 -7
  34. package/lib/LicenseByline/LicenseLink.d.ts +3 -4
  35. package/lib/LicenseByline/LicenseLink.js +6 -10
  36. package/lib/Messages/MessageBox.js +6 -6
  37. package/lib/index.d.ts +1 -3
  38. package/lib/index.js +6 -37
  39. package/lib/locale/messages-en.d.ts +17 -5
  40. package/lib/locale/messages-en.js +33 -21
  41. package/lib/locale/messages-nb.d.ts +17 -5
  42. package/lib/locale/messages-nb.js +33 -21
  43. package/lib/locale/messages-nn.d.ts +17 -5
  44. package/lib/locale/messages-nn.js +32 -20
  45. package/lib/locale/messages-se.d.ts +17 -5
  46. package/lib/locale/messages-se.js +34 -22
  47. package/lib/locale/messages-sma.d.ts +17 -5
  48. package/lib/locale/messages-sma.js +33 -21
  49. package/package.json +9 -10
  50. package/src/ContactBlock/ContactBlock.tsx +1 -1
  51. package/src/Embed/AudioEmbed.stories.tsx +0 -5
  52. package/src/Embed/AudioEmbed.tsx +3 -40
  53. package/src/Embed/BrightcoveEmbed.stories.tsx +0 -4
  54. package/src/Embed/BrightcoveEmbed.tsx +2 -5
  55. package/src/Embed/ConceptEmbed.stories.tsx +0 -5
  56. package/src/Embed/ConceptEmbed.tsx +4 -26
  57. package/src/Embed/ImageEmbed.stories.tsx +0 -12
  58. package/src/Embed/ImageEmbed.tsx +33 -89
  59. package/src/Embed/UuDisclaimerEmbed.tsx +2 -1
  60. package/src/Embed/conceptComponents.tsx +14 -12
  61. package/src/LicenseByline/EmbedByline.stories.tsx +1 -26
  62. package/src/LicenseByline/EmbedByline.tsx +50 -82
  63. package/src/LicenseByline/LicenseDescription.tsx +65 -8
  64. package/src/LicenseByline/LicenseLink.tsx +6 -12
  65. package/src/Messages/MessageBox.tsx +1 -0
  66. package/src/index.ts +1 -12
  67. package/src/locale/messages-en.ts +29 -17
  68. package/src/locale/messages-nb.ts +29 -17
  69. package/src/locale/messages-nn.ts +29 -17
  70. package/src/locale/messages-se.ts +30 -18
  71. package/src/locale/messages-sma.ts +29 -17
  72. package/es/MediaList/MediaList.js +0 -215
  73. package/es/MediaList/index.js +0 -8
  74. package/lib/MediaList/MediaList.d.ts +0 -49
  75. package/lib/MediaList/MediaList.js +0 -227
  76. package/lib/MediaList/index.d.ts +0 -9
  77. package/lib/MediaList/index.js +0 -42
  78. package/src/MediaList/MediaList.tsx +0 -285
  79. package/src/MediaList/index.ts +0 -17
@@ -11,15 +11,15 @@ import _styled from "@emotion/styled/base";
11
11
  import parse from "html-react-parser";
12
12
  import { useMemo, useState } from "react";
13
13
  import { useTranslation } from "react-i18next";
14
- import { colors, spacing, utils } from "@ndla/core";
14
+ import { colors, spacing } from "@ndla/core";
15
15
  import { ExpandTwoArrows } from "@ndla/icons/action";
16
16
  import { ArrowCollapse, ChevronDown, ChevronUp } from "@ndla/icons/common";
17
17
  import { COPYRIGHTED } from "@ndla/licenses";
18
18
  import EmbedErrorPlaceholder from "./EmbedErrorPlaceholder";
19
19
  import { Figure, figureActionIndicatorStyle } from "../Figure";
20
- import Image, { ImageLink } from "../Image";
20
+ import Image from "../Image";
21
21
  import { EmbedByline } from "../LicenseByline";
22
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
22
+ import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
23
23
  export const getLicenseCredits = copyright => {
24
24
  var _copyright$creators, _copyright$rightshold, _copyright$processors;
25
25
  return {
@@ -85,18 +85,15 @@ export const getCrop = data => {
85
85
  };
86
86
  const expandedSizes = "(min-width: 1024px) 1024px, 100vw";
87
87
  const StyledFigure = /*#__PURE__*/_styled(Figure, {
88
- target: "ened8ka2",
88
+ target: "ened8ka1",
89
89
  label: "StyledFigure"
90
- })("&:hover{[data-byline-button]{background:", colors.white, ";svg{transform:scale(1.2);}}}&[data-float=\"right\"]{float:right;}&[data-float=\"left\"]{float:left;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAoHmC","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n/** @jsxImportSource @emotion/react */\nimport parse from \"html-react-parser\";\nimport { MouseEventHandler, ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { colors, spacing, utils } from \"@ndla/core\";\nimport { ExpandTwoArrows } from \"@ndla/icons/action\";\nimport { ArrowCollapse, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ImageEmbedData, ImageMetaData } from \"@ndla/types-embed\";\nimport EmbedErrorPlaceholder from \"./EmbedErrorPlaceholder\";\nimport { CanonicalUrlFuncs, HeartButtonType, RenderContext } from \"./types\";\nimport { Figure, FigureType, figureActionIndicatorStyle } from \"../Figure\";\nimport Image, { ImageLink } from \"../Image\";\nimport { EmbedByline } from \"../LicenseByline\";\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  path?: string;\n  heartButton?: HeartButtonType;\n  canonicalUrl?: CanonicalUrlFuncs[\"image\"];\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n  children?: ReactNode;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is \"xsmall\" | \"small\" => size === \"xsmall\" || size === \"small\";\n\nconst isAlign = (align?: string): align is \"left\" | \"right\" => align === \"left\" || align === \"right\";\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return \"full\";\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === \"full\") {\n    return \"(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw\";\n  }\n  if (align && size === \"small\") {\n    return \"(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw\";\n  }\n  if (align && size === \"xsmall\") {\n    return \"(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw\";\n  }\n  return \"(min-width: 1024px) 1024px, 100vw\";\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = Number.parseFloat(data.focalX ?? \"\");\n  const focalY = Number.parseFloat(data.focalY ?? \"\");\n  if (!Number.isNaN(focalX) && !Number.isNaN(focalY)) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = Number.parseFloat(data.lowerRightX ?? \"\");\n  const lowerRightY = Number.parseFloat(data.lowerRightY ?? \"\");\n  const upperLeftX = Number.parseFloat(data.upperLeftX ?? \"\");\n  const upperLeftY = Number.parseFloat(data.upperLeftY ?? \"\");\n  if (\n    !Number.isNaN(lowerRightX) &&\n    !Number.isNaN(lowerRightY) &&\n    !Number.isNaN(upperLeftX) &&\n    !Number.isNaN(upperLeftY)\n  ) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = \"(min-width: 1024px) 1024px, 100vw\";\n\nconst StyledFigure = styled(Figure)`\n  &:hover {\n    [data-byline-button] {\n      background: ${colors.white};\n      svg {\n        transform: scale(1.2);\n      }\n    }\n  }\n  &[data-float=\"right\"] {\n    float: right;\n  }\n  &[data-float=\"left\"] {\n    float: left;\n  }\n`;\n\nconst ImageEmbed = ({\n  embed,\n  previewAlt,\n  heartButton: HeartButton,\n  inGrid,\n  path,\n  lang,\n  canonicalUrl,\n  renderContext = \"article\",\n  children,\n}: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  // Full-size figures automatically get a margin of {spacing.normal} on its y-axis if a float is not set (or if float is an empty string).\n  // This adds some margin to normal figures within an article, but should not happen for figures in a grid.\n  const [floatAttr, setFloatAttr] = useState<{ \"data-float\"?: string }>(() =>\n    inGrid && !embed.embedData.align ? {} : { \"data-float\": embed.embedData.align },\n  );\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === \"article\") {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    }\n    if (embed.status === \"success\" && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === \"error\") {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={\"image\"} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || \"\";\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <StyledFigure type={imageSizes ? undefined : figureType} {...floatAttr}>\n      {children}\n      <ImageWrapper\n        src={!isCopyrighted ? canonicalUrl?.(data) : undefined}\n        crop={crop}\n        embedData={embedData}\n        pagePath={path}\n      >\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.image.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.image.imageUrl}\n          border={embedData.border}\n          expandButton={\n            <ExpandButton\n              embedData={embedData}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => {\n                if (!imageSizes) {\n                  setImageSizes(expandedSizes);\n                  setTimeout(() => {\n                    setFloatAttr({});\n                  }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless\n                } else {\n                  setImageSizes(undefined);\n                  setFloatAttr({ \"data-float\": embedData.align });\n                }\n              }}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n          lang={lang}\n        />\n      </ImageWrapper>\n      {isBylineHidden ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          hideOnLargeScreens={isSmall(embedData.size) && !imageSizes}\n          description={parsedDescription}\n          bottomRounded\n          visibleAlt={previewAlt ? embed.embedData.alt : \"\"}\n          inGrid={inGrid}\n        >\n          {HeartButton && !isCopyrighted && <HeartButton embed={embed} />}\n        </EmbedByline>\n      )}\n    </StyledFigure>\n  );\n};\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ninterface ImageWrapperProps {\n  src?: string;\n  children: React.ReactNode;\n  pagePath?: string;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  embedData: ImageEmbedData;\n}\n\nconst hideByline = (embed: ImageEmbedData): boolean => {\n  return (!!embed.size && embed.size.endsWith(\"-hide-byline\")) || embed.hideByline === \"true\";\n};\n\nconst ImageWrapper = ({ src, crop, children, pagePath, embedData }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size) || hideByline(embedData) || !src || (pagePath && src.endsWith(pagePath))) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop}>\n      {children}\n      <HiddenSpan>{t(\"license.images.itemImage.ariaLabel\")}</HiddenSpan>\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  embedData: ImageEmbedData;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst BylineButton = styled.button`\n  cursor: pointer;\n  position: absolute;\n  z-index: 1;\n  bottom: 0;\n  right: 0;\n  padding: ${spacing.small};\n  transition: all 0.3s ease-out;\n  background: ${colors.background.default}20;\n  border: 0;\n\n  svg {\n    transition: transform 0.4s ease-out;\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n    fill: ${colors.brand.primary};\n  }\n`;\n\nconst ExpandButton = ({ embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size)) {\n    return (\n      <button\n        type=\"button\"\n        css={figureActionIndicatorStyle}\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  }\n  if (hideByline(embedData)) {\n    return (\n      <BylineButton\n        type=\"button\"\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? \"expandByline\" : \"minimizeByline\"}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </BylineButton>\n    );\n  }\n  return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
90
+ })("&:hover{[data-byline-button]{background:", colors.white, ";svg{transform:scale(1.2);}}}&[data-float=\"right\"]{float:right;}&[data-float=\"left\"]{float:left;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAiHmC","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n/** @jsxImportSource @emotion/react */\nimport parse from \"html-react-parser\";\nimport { MouseEventHandler, ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { colors, spacing } from \"@ndla/core\";\nimport { ExpandTwoArrows } from \"@ndla/icons/action\";\nimport { ArrowCollapse, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ImageEmbedData, ImageMetaData } from \"@ndla/types-embed\";\nimport EmbedErrorPlaceholder from \"./EmbedErrorPlaceholder\";\nimport { RenderContext } from \"./types\";\nimport { Figure, FigureType, figureActionIndicatorStyle } from \"../Figure\";\nimport Image from \"../Image\";\nimport { EmbedByline } from \"../LicenseByline\";\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n  children?: ReactNode;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is \"xsmall\" | \"small\" => size === \"xsmall\" || size === \"small\";\n\nconst isAlign = (align?: string): align is \"left\" | \"right\" => align === \"left\" || align === \"right\";\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return \"full\";\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === \"full\") {\n    return \"(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw\";\n  }\n  if (align && size === \"small\") {\n    return \"(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw\";\n  }\n  if (align && size === \"xsmall\") {\n    return \"(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw\";\n  }\n  return \"(min-width: 1024px) 1024px, 100vw\";\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = Number.parseFloat(data.focalX ?? \"\");\n  const focalY = Number.parseFloat(data.focalY ?? \"\");\n  if (!Number.isNaN(focalX) && !Number.isNaN(focalY)) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = Number.parseFloat(data.lowerRightX ?? \"\");\n  const lowerRightY = Number.parseFloat(data.lowerRightY ?? \"\");\n  const upperLeftX = Number.parseFloat(data.upperLeftX ?? \"\");\n  const upperLeftY = Number.parseFloat(data.upperLeftY ?? \"\");\n  if (\n    !Number.isNaN(lowerRightX) &&\n    !Number.isNaN(lowerRightY) &&\n    !Number.isNaN(upperLeftX) &&\n    !Number.isNaN(upperLeftY)\n  ) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = \"(min-width: 1024px) 1024px, 100vw\";\n\nconst StyledFigure = styled(Figure)`\n  &:hover {\n    [data-byline-button] {\n      background: ${colors.white};\n      svg {\n        transform: scale(1.2);\n      }\n    }\n  }\n  &[data-float=\"right\"] {\n    float: right;\n  }\n  &[data-float=\"left\"] {\n    float: left;\n  }\n`;\n\nconst ImageEmbed = ({ embed, previewAlt, inGrid, lang, renderContext = \"article\", children }: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  // Full-size figures automatically get a margin of {spacing.normal} on its y-axis if a float is not set (or if float is an empty string).\n  // This adds some margin to normal figures within an article, but should not happen for figures in a grid.\n  const [floatAttr, setFloatAttr] = useState<{ \"data-float\"?: string }>(() =>\n    inGrid && !embed.embedData.align ? {} : { \"data-float\": embed.embedData.align },\n  );\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === \"article\") {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    }\n    if (embed.status === \"success\" && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === \"error\") {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={\"image\"} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || \"\";\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <StyledFigure type={imageSizes ? undefined : figureType} {...floatAttr}>\n      {children}\n      <Image\n        focalPoint={focalPoint}\n        contentType={data.image.contentType}\n        crop={crop}\n        sizes={imageSizes ?? sizes}\n        alt={altText}\n        src={data.image.imageUrl}\n        border={embedData.border}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            bylineHidden={isBylineHidden}\n            onExpand={() => {\n              if (!imageSizes) {\n                setImageSizes(expandedSizes);\n                setTimeout(() => {\n                  setFloatAttr({});\n                }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless\n              } else {\n                setImageSizes(undefined);\n                setFloatAttr({ \"data-float\": embedData.align });\n              }\n            }}\n            onHideByline={() => setIsBylineHidden((p) => !p)}\n          />\n        }\n        lang={lang}\n      />\n      {isBylineHidden ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          description={parsedDescription}\n          visibleAlt={previewAlt ? embed.embedData.alt : \"\"}\n        />\n      )}\n    </StyledFigure>\n  );\n};\n\nconst hideByline = (embed: ImageEmbedData): boolean => {\n  return (!!embed.size && embed.size.endsWith(\"-hide-byline\")) || embed.hideByline === \"true\";\n};\n\ninterface ExpandButtonProps {\n  embedData: ImageEmbedData;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst BylineButton = styled.button`\n  cursor: pointer;\n  position: absolute;\n  z-index: 1;\n  bottom: 0;\n  right: 0;\n  padding: ${spacing.small};\n  transition: all 0.3s ease-out;\n  background: ${colors.background.default}20;\n  border: 0;\n\n  svg {\n    transition: transform 0.4s ease-out;\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n    fill: ${colors.brand.primary};\n  }\n`;\n\nconst ExpandButton = ({ embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size)) {\n    return (\n      <button\n        type=\"button\"\n        css={figureActionIndicatorStyle}\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  }\n  if (hideByline(embedData)) {\n    return (\n      <BylineButton\n        type=\"button\"\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? \"expandByline\" : \"minimizeByline\"}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </BylineButton>\n    );\n  }\n  return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
91
91
  const ImageEmbed = _ref => {
92
92
  let {
93
93
  embed,
94
94
  previewAlt,
95
- heartButton: HeartButton,
96
95
  inGrid,
97
- path,
98
96
  lang,
99
- canonicalUrl,
100
97
  renderContext = "article",
101
98
  children
102
99
  } = _ref;
@@ -139,97 +136,57 @@ const ImageEmbed = _ref => {
139
136
  return _jsxs(StyledFigure, {
140
137
  type: imageSizes ? undefined : figureType,
141
138
  ...floatAttr,
142
- children: [children, _jsx(ImageWrapper, {
143
- src: !isCopyrighted ? canonicalUrl === null || canonicalUrl === void 0 ? void 0 : canonicalUrl(data) : undefined,
139
+ children: [children, _jsx(Image, {
140
+ focalPoint: focalPoint,
141
+ contentType: data.image.contentType,
144
142
  crop: crop,
145
- embedData: embedData,
146
- pagePath: path,
147
- children: _jsx(Image, {
148
- focalPoint: focalPoint,
149
- contentType: data.image.contentType,
150
- crop: crop,
151
- sizes: imageSizes !== null && imageSizes !== void 0 ? imageSizes : sizes,
152
- alt: altText,
153
- src: data.image.imageUrl,
154
- border: embedData.border,
155
- expandButton: _jsx(ExpandButton, {
156
- embedData: embedData,
157
- expanded: !!imageSizes,
158
- bylineHidden: isBylineHidden,
159
- onExpand: () => {
160
- if (!imageSizes) {
161
- setImageSizes(expandedSizes);
162
- setTimeout(() => {
163
- setFloatAttr({});
164
- }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless
165
- } else {
166
- setImageSizes(undefined);
167
- setFloatAttr({
168
- "data-float": embedData.align
169
- });
170
- }
171
- },
172
- onHideByline: () => setIsBylineHidden(p => !p)
173
- }),
174
- lang: lang
175
- })
143
+ sizes: imageSizes !== null && imageSizes !== void 0 ? imageSizes : sizes,
144
+ alt: altText,
145
+ src: data.image.imageUrl,
146
+ border: embedData.border,
147
+ expandButton: _jsx(ExpandButton, {
148
+ embedData: embedData,
149
+ expanded: !!imageSizes,
150
+ bylineHidden: isBylineHidden,
151
+ onExpand: () => {
152
+ if (!imageSizes) {
153
+ setImageSizes(expandedSizes);
154
+ setTimeout(() => {
155
+ setFloatAttr({});
156
+ }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless
157
+ } else {
158
+ setImageSizes(undefined);
159
+ setFloatAttr({
160
+ "data-float": embedData.align
161
+ });
162
+ }
163
+ },
164
+ onHideByline: () => setIsBylineHidden(p => !p)
165
+ }),
166
+ lang: lang
176
167
  }), isBylineHidden ? null : _jsx(EmbedByline, {
177
168
  type: "image",
178
169
  copyright: data.copyright,
179
- hideOnLargeScreens: isSmall(embedData.size) && !imageSizes,
180
170
  description: parsedDescription,
181
- bottomRounded: true,
182
- visibleAlt: previewAlt ? embed.embedData.alt : "",
183
- inGrid: inGrid,
184
- children: HeartButton && !isCopyrighted && _jsx(HeartButton, {
185
- embed: embed
186
- })
171
+ visibleAlt: previewAlt ? embed.embedData.alt : ""
187
172
  })]
188
173
  });
189
174
  };
190
- const HiddenSpan = /*#__PURE__*/_styled("span", {
191
- target: "ened8ka1",
192
- label: "HiddenSpan"
193
- })(utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AA2O8B","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n/** @jsxImportSource @emotion/react */\nimport parse from \"html-react-parser\";\nimport { MouseEventHandler, ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { colors, spacing, utils } from \"@ndla/core\";\nimport { ExpandTwoArrows } from \"@ndla/icons/action\";\nimport { ArrowCollapse, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ImageEmbedData, ImageMetaData } from \"@ndla/types-embed\";\nimport EmbedErrorPlaceholder from \"./EmbedErrorPlaceholder\";\nimport { CanonicalUrlFuncs, HeartButtonType, RenderContext } from \"./types\";\nimport { Figure, FigureType, figureActionIndicatorStyle } from \"../Figure\";\nimport Image, { ImageLink } from \"../Image\";\nimport { EmbedByline } from \"../LicenseByline\";\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  path?: string;\n  heartButton?: HeartButtonType;\n  canonicalUrl?: CanonicalUrlFuncs[\"image\"];\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n  children?: ReactNode;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is \"xsmall\" | \"small\" => size === \"xsmall\" || size === \"small\";\n\nconst isAlign = (align?: string): align is \"left\" | \"right\" => align === \"left\" || align === \"right\";\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return \"full\";\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === \"full\") {\n    return \"(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw\";\n  }\n  if (align && size === \"small\") {\n    return \"(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw\";\n  }\n  if (align && size === \"xsmall\") {\n    return \"(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw\";\n  }\n  return \"(min-width: 1024px) 1024px, 100vw\";\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = Number.parseFloat(data.focalX ?? \"\");\n  const focalY = Number.parseFloat(data.focalY ?? \"\");\n  if (!Number.isNaN(focalX) && !Number.isNaN(focalY)) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = Number.parseFloat(data.lowerRightX ?? \"\");\n  const lowerRightY = Number.parseFloat(data.lowerRightY ?? \"\");\n  const upperLeftX = Number.parseFloat(data.upperLeftX ?? \"\");\n  const upperLeftY = Number.parseFloat(data.upperLeftY ?? \"\");\n  if (\n    !Number.isNaN(lowerRightX) &&\n    !Number.isNaN(lowerRightY) &&\n    !Number.isNaN(upperLeftX) &&\n    !Number.isNaN(upperLeftY)\n  ) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = \"(min-width: 1024px) 1024px, 100vw\";\n\nconst StyledFigure = styled(Figure)`\n  &:hover {\n    [data-byline-button] {\n      background: ${colors.white};\n      svg {\n        transform: scale(1.2);\n      }\n    }\n  }\n  &[data-float=\"right\"] {\n    float: right;\n  }\n  &[data-float=\"left\"] {\n    float: left;\n  }\n`;\n\nconst ImageEmbed = ({\n  embed,\n  previewAlt,\n  heartButton: HeartButton,\n  inGrid,\n  path,\n  lang,\n  canonicalUrl,\n  renderContext = \"article\",\n  children,\n}: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  // Full-size figures automatically get a margin of {spacing.normal} on its y-axis if a float is not set (or if float is an empty string).\n  // This adds some margin to normal figures within an article, but should not happen for figures in a grid.\n  const [floatAttr, setFloatAttr] = useState<{ \"data-float\"?: string }>(() =>\n    inGrid && !embed.embedData.align ? {} : { \"data-float\": embed.embedData.align },\n  );\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === \"article\") {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    }\n    if (embed.status === \"success\" && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === \"error\") {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={\"image\"} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || \"\";\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <StyledFigure type={imageSizes ? undefined : figureType} {...floatAttr}>\n      {children}\n      <ImageWrapper\n        src={!isCopyrighted ? canonicalUrl?.(data) : undefined}\n        crop={crop}\n        embedData={embedData}\n        pagePath={path}\n      >\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.image.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.image.imageUrl}\n          border={embedData.border}\n          expandButton={\n            <ExpandButton\n              embedData={embedData}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => {\n                if (!imageSizes) {\n                  setImageSizes(expandedSizes);\n                  setTimeout(() => {\n                    setFloatAttr({});\n                  }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless\n                } else {\n                  setImageSizes(undefined);\n                  setFloatAttr({ \"data-float\": embedData.align });\n                }\n              }}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n          lang={lang}\n        />\n      </ImageWrapper>\n      {isBylineHidden ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          hideOnLargeScreens={isSmall(embedData.size) && !imageSizes}\n          description={parsedDescription}\n          bottomRounded\n          visibleAlt={previewAlt ? embed.embedData.alt : \"\"}\n          inGrid={inGrid}\n        >\n          {HeartButton && !isCopyrighted && <HeartButton embed={embed} />}\n        </EmbedByline>\n      )}\n    </StyledFigure>\n  );\n};\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ninterface ImageWrapperProps {\n  src?: string;\n  children: React.ReactNode;\n  pagePath?: string;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  embedData: ImageEmbedData;\n}\n\nconst hideByline = (embed: ImageEmbedData): boolean => {\n  return (!!embed.size && embed.size.endsWith(\"-hide-byline\")) || embed.hideByline === \"true\";\n};\n\nconst ImageWrapper = ({ src, crop, children, pagePath, embedData }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size) || hideByline(embedData) || !src || (pagePath && src.endsWith(pagePath))) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop}>\n      {children}\n      <HiddenSpan>{t(\"license.images.itemImage.ariaLabel\")}</HiddenSpan>\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  embedData: ImageEmbedData;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst BylineButton = styled.button`\n  cursor: pointer;\n  position: absolute;\n  z-index: 1;\n  bottom: 0;\n  right: 0;\n  padding: ${spacing.small};\n  transition: all 0.3s ease-out;\n  background: ${colors.background.default}20;\n  border: 0;\n\n  svg {\n    transition: transform 0.4s ease-out;\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n    fill: ${colors.brand.primary};\n  }\n`;\n\nconst ExpandButton = ({ embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size)) {\n    return (\n      <button\n        type=\"button\"\n        css={figureActionIndicatorStyle}\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  }\n  if (hideByline(embedData)) {\n    return (\n      <BylineButton\n        type=\"button\"\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? \"expandByline\" : \"minimizeByline\"}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </BylineButton>\n    );\n  }\n  return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
194
175
  const hideByline = embed => {
195
176
  return !!embed.size && embed.size.endsWith("-hide-byline") || embed.hideByline === "true";
196
177
  };
197
- const ImageWrapper = _ref2 => {
198
- let {
199
- src,
200
- crop,
201
- children,
202
- pagePath,
203
- embedData
204
- } = _ref2;
205
- const {
206
- t
207
- } = useTranslation();
208
- if (isSmall(embedData.size) || hideByline(embedData) || !src || pagePath && src.endsWith(pagePath)) {
209
- return _jsx(_Fragment, {
210
- children: children
211
- });
212
- }
213
- return _jsxs(ImageLink, {
214
- src: src,
215
- crop: crop,
216
- children: [children, _jsx(HiddenSpan, {
217
- children: t("license.images.itemImage.ariaLabel")
218
- })]
219
- });
220
- };
221
178
  const BylineButton = /*#__PURE__*/_styled("button", {
222
179
  target: "ened8ka0",
223
180
  label: "BylineButton"
224
- })("cursor:pointer;position:absolute;z-index:1;bottom:0;right:0;padding:", spacing.small, ";transition:all 0.3s ease-out;background:", colors.background.default, "20;border:0;svg{transition:transform 0.4s ease-out;width:", spacing.normal, ";height:", spacing.normal, ";fill:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAsRkC","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n/** @jsxImportSource @emotion/react */\nimport parse from \"html-react-parser\";\nimport { MouseEventHandler, ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { colors, spacing, utils } from \"@ndla/core\";\nimport { ExpandTwoArrows } from \"@ndla/icons/action\";\nimport { ArrowCollapse, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ImageEmbedData, ImageMetaData } from \"@ndla/types-embed\";\nimport EmbedErrorPlaceholder from \"./EmbedErrorPlaceholder\";\nimport { CanonicalUrlFuncs, HeartButtonType, RenderContext } from \"./types\";\nimport { Figure, FigureType, figureActionIndicatorStyle } from \"../Figure\";\nimport Image, { ImageLink } from \"../Image\";\nimport { EmbedByline } from \"../LicenseByline\";\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  path?: string;\n  heartButton?: HeartButtonType;\n  canonicalUrl?: CanonicalUrlFuncs[\"image\"];\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n  children?: ReactNode;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is \"xsmall\" | \"small\" => size === \"xsmall\" || size === \"small\";\n\nconst isAlign = (align?: string): align is \"left\" | \"right\" => align === \"left\" || align === \"right\";\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return \"full\";\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === \"full\") {\n    return \"(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw\";\n  }\n  if (align && size === \"small\") {\n    return \"(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw\";\n  }\n  if (align && size === \"xsmall\") {\n    return \"(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw\";\n  }\n  return \"(min-width: 1024px) 1024px, 100vw\";\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = Number.parseFloat(data.focalX ?? \"\");\n  const focalY = Number.parseFloat(data.focalY ?? \"\");\n  if (!Number.isNaN(focalX) && !Number.isNaN(focalY)) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = Number.parseFloat(data.lowerRightX ?? \"\");\n  const lowerRightY = Number.parseFloat(data.lowerRightY ?? \"\");\n  const upperLeftX = Number.parseFloat(data.upperLeftX ?? \"\");\n  const upperLeftY = Number.parseFloat(data.upperLeftY ?? \"\");\n  if (\n    !Number.isNaN(lowerRightX) &&\n    !Number.isNaN(lowerRightY) &&\n    !Number.isNaN(upperLeftX) &&\n    !Number.isNaN(upperLeftY)\n  ) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = \"(min-width: 1024px) 1024px, 100vw\";\n\nconst StyledFigure = styled(Figure)`\n  &:hover {\n    [data-byline-button] {\n      background: ${colors.white};\n      svg {\n        transform: scale(1.2);\n      }\n    }\n  }\n  &[data-float=\"right\"] {\n    float: right;\n  }\n  &[data-float=\"left\"] {\n    float: left;\n  }\n`;\n\nconst ImageEmbed = ({\n  embed,\n  previewAlt,\n  heartButton: HeartButton,\n  inGrid,\n  path,\n  lang,\n  canonicalUrl,\n  renderContext = \"article\",\n  children,\n}: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  // Full-size figures automatically get a margin of {spacing.normal} on its y-axis if a float is not set (or if float is an empty string).\n  // This adds some margin to normal figures within an article, but should not happen for figures in a grid.\n  const [floatAttr, setFloatAttr] = useState<{ \"data-float\"?: string }>(() =>\n    inGrid && !embed.embedData.align ? {} : { \"data-float\": embed.embedData.align },\n  );\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === \"article\") {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    }\n    if (embed.status === \"success\" && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === \"error\") {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={\"image\"} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || \"\";\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <StyledFigure type={imageSizes ? undefined : figureType} {...floatAttr}>\n      {children}\n      <ImageWrapper\n        src={!isCopyrighted ? canonicalUrl?.(data) : undefined}\n        crop={crop}\n        embedData={embedData}\n        pagePath={path}\n      >\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.image.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.image.imageUrl}\n          border={embedData.border}\n          expandButton={\n            <ExpandButton\n              embedData={embedData}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => {\n                if (!imageSizes) {\n                  setImageSizes(expandedSizes);\n                  setTimeout(() => {\n                    setFloatAttr({});\n                  }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless\n                } else {\n                  setImageSizes(undefined);\n                  setFloatAttr({ \"data-float\": embedData.align });\n                }\n              }}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n          lang={lang}\n        />\n      </ImageWrapper>\n      {isBylineHidden ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          hideOnLargeScreens={isSmall(embedData.size) && !imageSizes}\n          description={parsedDescription}\n          bottomRounded\n          visibleAlt={previewAlt ? embed.embedData.alt : \"\"}\n          inGrid={inGrid}\n        >\n          {HeartButton && !isCopyrighted && <HeartButton embed={embed} />}\n        </EmbedByline>\n      )}\n    </StyledFigure>\n  );\n};\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ninterface ImageWrapperProps {\n  src?: string;\n  children: React.ReactNode;\n  pagePath?: string;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  embedData: ImageEmbedData;\n}\n\nconst hideByline = (embed: ImageEmbedData): boolean => {\n  return (!!embed.size && embed.size.endsWith(\"-hide-byline\")) || embed.hideByline === \"true\";\n};\n\nconst ImageWrapper = ({ src, crop, children, pagePath, embedData }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size) || hideByline(embedData) || !src || (pagePath && src.endsWith(pagePath))) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop}>\n      {children}\n      <HiddenSpan>{t(\"license.images.itemImage.ariaLabel\")}</HiddenSpan>\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  embedData: ImageEmbedData;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst BylineButton = styled.button`\n  cursor: pointer;\n  position: absolute;\n  z-index: 1;\n  bottom: 0;\n  right: 0;\n  padding: ${spacing.small};\n  transition: all 0.3s ease-out;\n  background: ${colors.background.default}20;\n  border: 0;\n\n  svg {\n    transition: transform 0.4s ease-out;\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n    fill: ${colors.brand.primary};\n  }\n`;\n\nconst ExpandButton = ({ embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size)) {\n    return (\n      <button\n        type=\"button\"\n        css={figureActionIndicatorStyle}\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  }\n  if (hideByline(embedData)) {\n    return (\n      <BylineButton\n        type=\"button\"\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? \"expandByline\" : \"minimizeByline\"}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </BylineButton>\n    );\n  }\n  return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
225
- const ExpandButton = _ref3 => {
181
+ })("cursor:pointer;position:absolute;z-index:1;bottom:0;right:0;padding:", spacing.small, ";transition:all 0.3s ease-out;background:", colors.background.default, "20;border:0;svg{transition:transform 0.4s ease-out;width:", spacing.normal, ";height:", spacing.normal, ";fill:", colors.brand.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AA8NkC","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n/** @jsxImportSource @emotion/react */\nimport parse from \"html-react-parser\";\nimport { MouseEventHandler, ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { colors, spacing } from \"@ndla/core\";\nimport { ExpandTwoArrows } from \"@ndla/icons/action\";\nimport { ArrowCollapse, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ImageEmbedData, ImageMetaData } from \"@ndla/types-embed\";\nimport EmbedErrorPlaceholder from \"./EmbedErrorPlaceholder\";\nimport { RenderContext } from \"./types\";\nimport { Figure, FigureType, figureActionIndicatorStyle } from \"../Figure\";\nimport Image from \"../Image\";\nimport { EmbedByline } from \"../LicenseByline\";\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n  children?: ReactNode;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is \"xsmall\" | \"small\" => size === \"xsmall\" || size === \"small\";\n\nconst isAlign = (align?: string): align is \"left\" | \"right\" => align === \"left\" || align === \"right\";\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return \"full\";\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === \"full\") {\n    return \"(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw\";\n  }\n  if (align && size === \"small\") {\n    return \"(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw\";\n  }\n  if (align && size === \"xsmall\") {\n    return \"(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw\";\n  }\n  return \"(min-width: 1024px) 1024px, 100vw\";\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = Number.parseFloat(data.focalX ?? \"\");\n  const focalY = Number.parseFloat(data.focalY ?? \"\");\n  if (!Number.isNaN(focalX) && !Number.isNaN(focalY)) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = Number.parseFloat(data.lowerRightX ?? \"\");\n  const lowerRightY = Number.parseFloat(data.lowerRightY ?? \"\");\n  const upperLeftX = Number.parseFloat(data.upperLeftX ?? \"\");\n  const upperLeftY = Number.parseFloat(data.upperLeftY ?? \"\");\n  if (\n    !Number.isNaN(lowerRightX) &&\n    !Number.isNaN(lowerRightY) &&\n    !Number.isNaN(upperLeftX) &&\n    !Number.isNaN(upperLeftY)\n  ) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = \"(min-width: 1024px) 1024px, 100vw\";\n\nconst StyledFigure = styled(Figure)`\n  &:hover {\n    [data-byline-button] {\n      background: ${colors.white};\n      svg {\n        transform: scale(1.2);\n      }\n    }\n  }\n  &[data-float=\"right\"] {\n    float: right;\n  }\n  &[data-float=\"left\"] {\n    float: left;\n  }\n`;\n\nconst ImageEmbed = ({ embed, previewAlt, inGrid, lang, renderContext = \"article\", children }: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  // Full-size figures automatically get a margin of {spacing.normal} on its y-axis if a float is not set (or if float is an empty string).\n  // This adds some margin to normal figures within an article, but should not happen for figures in a grid.\n  const [floatAttr, setFloatAttr] = useState<{ \"data-float\"?: string }>(() =>\n    inGrid && !embed.embedData.align ? {} : { \"data-float\": embed.embedData.align },\n  );\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === \"article\") {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    }\n    if (embed.status === \"success\" && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === \"error\") {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={\"image\"} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || \"\";\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <StyledFigure type={imageSizes ? undefined : figureType} {...floatAttr}>\n      {children}\n      <Image\n        focalPoint={focalPoint}\n        contentType={data.image.contentType}\n        crop={crop}\n        sizes={imageSizes ?? sizes}\n        alt={altText}\n        src={data.image.imageUrl}\n        border={embedData.border}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            bylineHidden={isBylineHidden}\n            onExpand={() => {\n              if (!imageSizes) {\n                setImageSizes(expandedSizes);\n                setTimeout(() => {\n                  setFloatAttr({});\n                }, 400); //Removing the float parameter too quickly causes the image to be resized from left regardless\n              } else {\n                setImageSizes(undefined);\n                setFloatAttr({ \"data-float\": embedData.align });\n              }\n            }}\n            onHideByline={() => setIsBylineHidden((p) => !p)}\n          />\n        }\n        lang={lang}\n      />\n      {isBylineHidden ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          description={parsedDescription}\n          visibleAlt={previewAlt ? embed.embedData.alt : \"\"}\n        />\n      )}\n    </StyledFigure>\n  );\n};\n\nconst hideByline = (embed: ImageEmbedData): boolean => {\n  return (!!embed.size && embed.size.endsWith(\"-hide-byline\")) || embed.hideByline === \"true\";\n};\n\ninterface ExpandButtonProps {\n  embedData: ImageEmbedData;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst BylineButton = styled.button`\n  cursor: pointer;\n  position: absolute;\n  z-index: 1;\n  bottom: 0;\n  right: 0;\n  padding: ${spacing.small};\n  transition: all 0.3s ease-out;\n  background: ${colors.background.default}20;\n  border: 0;\n\n  svg {\n    transition: transform 0.4s ease-out;\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n    fill: ${colors.brand.primary};\n  }\n`;\n\nconst ExpandButton = ({ embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(embedData.size)) {\n    return (\n      <button\n        type=\"button\"\n        css={figureActionIndicatorStyle}\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  }\n  if (hideByline(embedData)) {\n    return (\n      <BylineButton\n        type=\"button\"\n        data-byline-button=\"\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? \"expandByline\" : \"minimizeByline\"}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </BylineButton>\n    );\n  }\n  return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
182
+ const ExpandButton = _ref2 => {
226
183
  let {
227
184
  embedData,
228
185
  expanded,
229
186
  bylineHidden,
230
187
  onExpand,
231
188
  onHideByline
232
- } = _ref3;
189
+ } = _ref2;
233
190
  const {
234
191
  t
235
192
  } = useTranslation();
@@ -9,7 +9,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
9
9
  */
10
10
 
11
11
  import { useTranslation } from "react-i18next";
12
- import { spacing } from "@ndla/core";
12
+ import { fonts, spacing } from "@ndla/core";
13
13
  import { InformationOutline } from "@ndla/icons/common";
14
14
  import { SafeLink } from "@ndla/safelink";
15
15
  import { MessageBox } from "../Messages";
@@ -23,25 +23,17 @@ const StyledMessageBox = /*#__PURE__*/_styled(MessageBox, {
23
23
  } : {
24
24
  name: "nvjrcv",
25
25
  styles: "display:flex;flex-align:center",
26
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQjJDIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSW5mb3JtYXRpb25PdXRsaW5lIH0gZnJvbSBcIkBuZGxhL2ljb25zL2NvbW1vblwiO1xuaW1wb3J0IHsgU2FmZUxpbmsgfSBmcm9tIFwiQG5kbGEvc2FmZWxpbmtcIjtcbmltcG9ydCB7IFV1RGlzY2xhaW1lck1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBNZXNzYWdlQm94IH0gZnJvbSBcIi4uL01lc3NhZ2VzXCI7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogVXVEaXNjbGFpbWVyTWV0YURhdGE7XG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBTdHlsZWRNZXNzYWdlQm94ID0gc3R5bGVkKE1lc3NhZ2VCb3gpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxvdztcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC13ZWJraXQtdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tb3otdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tcy11c2VyLXNlbGVjdDogbm9uZTtcbmA7XG5cbmNvbnN0IERpc2NsYWltZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgPiA6bnRoLWNoaWxkKDIpIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgVXVEaXNjbGFpbWVyRW1iZWQgPSAoeyBlbWJlZCwgY2hpbGRyZW4gfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuXG4gIGlmIChlbWJlZC5zdGF0dXMgPT09IFwiZXJyb3JcIikge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgeyBlbWJlZERhdGEsIGRhdGEgfSA9IGVtYmVkO1xuXG4gIGNvbnN0IGRpc2NsYWltZXJMaW5rID0gZGF0YT8uZGlzY2xhaW1lckxpbmsgPyAoXG4gICAgPD5cbiAgICAgIHtgICR7dChcInV1RGlzY2xhaW1lci5hbHRlcm5hdGl2ZVwiKX0gYH1cbiAgICAgIDxTYWZlTGluayB0bz17ZGF0YS5kaXNjbGFpbWVyTGluay5ocmVmfSB0YXJnZXQ9XCJfYmxhbmtcIiByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCI+XG4gICAgICAgIHtkYXRhLmRpc2NsYWltZXJMaW5rLnRleHR9XG4gICAgICA8L1NhZmVMaW5rPlxuICAgIDwvPlxuICApIDogbnVsbDtcblxuICByZXR1cm4gKFxuICAgIDxEaXNjbGFpbWVyV3JhcHBlciByb2xlPVwicmVnaW9uXCI+XG4gICAgICA8U3R5bGVkTWVzc2FnZUJveCB0eXBlPVwiaW5mb1wiIGNvbnRlbnRFZGl0YWJsZT17ZmFsc2V9PlxuICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lIC8+XG4gICAgICAgIDxEaXNjbGFpbWVyPlxuICAgICAgICAgIHtlbWJlZERhdGEuZGlzY2xhaW1lcn1cbiAgICAgICAgICB7ZGlzY2xhaW1lckxpbmt9XG4gICAgICAgIDwvRGlzY2xhaW1lcj5cbiAgICAgIDwvU3R5bGVkTWVzc2FnZUJveD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0Rpc2NsYWltZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgVXVEaXNjbGFpbWVyRW1iZWQ7XG4iXX0= */",
26
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQjJDIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGZvbnRzLCBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEluZm9ybWF0aW9uT3V0bGluZSB9IGZyb20gXCJAbmRsYS9pY29ucy9jb21tb25cIjtcbmltcG9ydCB7IFNhZmVMaW5rIH0gZnJvbSBcIkBuZGxhL3NhZmVsaW5rXCI7XG5pbXBvcnQgeyBVdURpc2NsYWltZXJNZXRhRGF0YSB9IGZyb20gXCJAbmRsYS90eXBlcy1lbWJlZFwiO1xuaW1wb3J0IHsgTWVzc2FnZUJveCB9IGZyb20gXCIuLi9NZXNzYWdlc1wiO1xuaW50ZXJmYWNlIFByb3BzIHtcbiAgZW1iZWQ6IFV1RGlzY2xhaW1lck1ldGFEYXRhO1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgU3R5bGVkTWVzc2FnZUJveCA9IHN0eWxlZChNZXNzYWdlQm94KWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1hbGlnbjogY2VudGVyO1xuYDtcblxuY29uc3QgRGlzY2xhaW1lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsb3c7XG4gICR7Zm9udHMuc2l6ZXMoXCIxOHB4XCIsIFwiMjRweFwiKX07XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICAtd2Via2l0LXVzZXItc2VsZWN0OiBub25lO1xuICAtbW96LXVzZXItc2VsZWN0OiBub25lO1xuICAtbXMtdXNlci1zZWxlY3Q6IG5vbmU7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gID4gOm50aC1jaGlsZCgyKSB7XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IFV1RGlzY2xhaW1lckVtYmVkID0gKHsgZW1iZWQsIGNoaWxkcmVuIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICBpZiAoZW1iZWQuc3RhdHVzID09PSBcImVycm9yXCIpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcblxuICBjb25zdCBkaXNjbGFpbWVyTGluayA9IGRhdGE/LmRpc2NsYWltZXJMaW5rID8gKFxuICAgIDw+XG4gICAgICB7YCAke3QoXCJ1dURpc2NsYWltZXIuYWx0ZXJuYXRpdmVcIil9IGB9XG4gICAgICA8U2FmZUxpbmsgdG89e2RhdGEuZGlzY2xhaW1lckxpbmsuaHJlZn0gdGFyZ2V0PVwiX2JsYW5rXCIgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiPlxuICAgICAgICB7ZGF0YS5kaXNjbGFpbWVyTGluay50ZXh0fVxuICAgICAgPC9TYWZlTGluaz5cbiAgICA8Lz5cbiAgKSA6IG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICA8RGlzY2xhaW1lcldyYXBwZXIgcm9sZT1cInJlZ2lvblwiPlxuICAgICAgPFN0eWxlZE1lc3NhZ2VCb3ggdHlwZT1cImluZm9cIiBjb250ZW50RWRpdGFibGU9e2ZhbHNlfT5cbiAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZSAvPlxuICAgICAgICA8RGlzY2xhaW1lcj5cbiAgICAgICAgICB7ZW1iZWREYXRhLmRpc2NsYWltZXJ9XG4gICAgICAgICAge2Rpc2NsYWltZXJMaW5rfVxuICAgICAgICA8L0Rpc2NsYWltZXI+XG4gICAgICA8L1N0eWxlZE1lc3NhZ2VCb3g+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9EaXNjbGFpbWVyV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFV1RGlzY2xhaW1lckVtYmVkO1xuIl19 */",
27
27
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
28
28
  });
29
29
  const Disclaimer = /*#__PURE__*/_styled("div", {
30
30
  target: "e1pgbrp21",
31
31
  label: "Disclaimer"
32
- })(process.env.NODE_ENV === "production" ? {
33
- name: "1t3nmn7",
34
- styles: "display:flow;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none"
35
- } : {
36
- name: "1t3nmn7",
37
- styles: "display:flow;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none",
38
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQjZCIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSW5mb3JtYXRpb25PdXRsaW5lIH0gZnJvbSBcIkBuZGxhL2ljb25zL2NvbW1vblwiO1xuaW1wb3J0IHsgU2FmZUxpbmsgfSBmcm9tIFwiQG5kbGEvc2FmZWxpbmtcIjtcbmltcG9ydCB7IFV1RGlzY2xhaW1lck1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBNZXNzYWdlQm94IH0gZnJvbSBcIi4uL01lc3NhZ2VzXCI7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogVXVEaXNjbGFpbWVyTWV0YURhdGE7XG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBTdHlsZWRNZXNzYWdlQm94ID0gc3R5bGVkKE1lc3NhZ2VCb3gpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxvdztcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC13ZWJraXQtdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tb3otdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tcy11c2VyLXNlbGVjdDogbm9uZTtcbmA7XG5cbmNvbnN0IERpc2NsYWltZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgPiA6bnRoLWNoaWxkKDIpIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgVXVEaXNjbGFpbWVyRW1iZWQgPSAoeyBlbWJlZCwgY2hpbGRyZW4gfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuXG4gIGlmIChlbWJlZC5zdGF0dXMgPT09IFwiZXJyb3JcIikge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgeyBlbWJlZERhdGEsIGRhdGEgfSA9IGVtYmVkO1xuXG4gIGNvbnN0IGRpc2NsYWltZXJMaW5rID0gZGF0YT8uZGlzY2xhaW1lckxpbmsgPyAoXG4gICAgPD5cbiAgICAgIHtgICR7dChcInV1RGlzY2xhaW1lci5hbHRlcm5hdGl2ZVwiKX0gYH1cbiAgICAgIDxTYWZlTGluayB0bz17ZGF0YS5kaXNjbGFpbWVyTGluay5ocmVmfSB0YXJnZXQ9XCJfYmxhbmtcIiByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCI+XG4gICAgICAgIHtkYXRhLmRpc2NsYWltZXJMaW5rLnRleHR9XG4gICAgICA8L1NhZmVMaW5rPlxuICAgIDwvPlxuICApIDogbnVsbDtcblxuICByZXR1cm4gKFxuICAgIDxEaXNjbGFpbWVyV3JhcHBlciByb2xlPVwicmVnaW9uXCI+XG4gICAgICA8U3R5bGVkTWVzc2FnZUJveCB0eXBlPVwiaW5mb1wiIGNvbnRlbnRFZGl0YWJsZT17ZmFsc2V9PlxuICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lIC8+XG4gICAgICAgIDxEaXNjbGFpbWVyPlxuICAgICAgICAgIHtlbWJlZERhdGEuZGlzY2xhaW1lcn1cbiAgICAgICAgICB7ZGlzY2xhaW1lckxpbmt9XG4gICAgICAgIDwvRGlzY2xhaW1lcj5cbiAgICAgIDwvU3R5bGVkTWVzc2FnZUJveD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0Rpc2NsYWltZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgVXVEaXNjbGFpbWVyRW1iZWQ7XG4iXX0= */",
39
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
40
- });
32
+ })("display:flow;", fonts.sizes("18px", "24px"), ";user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQjZCIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGZvbnRzLCBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEluZm9ybWF0aW9uT3V0bGluZSB9IGZyb20gXCJAbmRsYS9pY29ucy9jb21tb25cIjtcbmltcG9ydCB7IFNhZmVMaW5rIH0gZnJvbSBcIkBuZGxhL3NhZmVsaW5rXCI7XG5pbXBvcnQgeyBVdURpc2NsYWltZXJNZXRhRGF0YSB9IGZyb20gXCJAbmRsYS90eXBlcy1lbWJlZFwiO1xuaW1wb3J0IHsgTWVzc2FnZUJveCB9IGZyb20gXCIuLi9NZXNzYWdlc1wiO1xuaW50ZXJmYWNlIFByb3BzIHtcbiAgZW1iZWQ6IFV1RGlzY2xhaW1lck1ldGFEYXRhO1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgU3R5bGVkTWVzc2FnZUJveCA9IHN0eWxlZChNZXNzYWdlQm94KWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1hbGlnbjogY2VudGVyO1xuYDtcblxuY29uc3QgRGlzY2xhaW1lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsb3c7XG4gICR7Zm9udHMuc2l6ZXMoXCIxOHB4XCIsIFwiMjRweFwiKX07XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICAtd2Via2l0LXVzZXItc2VsZWN0OiBub25lO1xuICAtbW96LXVzZXItc2VsZWN0OiBub25lO1xuICAtbXMtdXNlci1zZWxlY3Q6IG5vbmU7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gID4gOm50aC1jaGlsZCgyKSB7XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IFV1RGlzY2xhaW1lckVtYmVkID0gKHsgZW1iZWQsIGNoaWxkcmVuIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICBpZiAoZW1iZWQuc3RhdHVzID09PSBcImVycm9yXCIpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcblxuICBjb25zdCBkaXNjbGFpbWVyTGluayA9IGRhdGE/LmRpc2NsYWltZXJMaW5rID8gKFxuICAgIDw+XG4gICAgICB7YCAke3QoXCJ1dURpc2NsYWltZXIuYWx0ZXJuYXRpdmVcIil9IGB9XG4gICAgICA8U2FmZUxpbmsgdG89e2RhdGEuZGlzY2xhaW1lckxpbmsuaHJlZn0gdGFyZ2V0PVwiX2JsYW5rXCIgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiPlxuICAgICAgICB7ZGF0YS5kaXNjbGFpbWVyTGluay50ZXh0fVxuICAgICAgPC9TYWZlTGluaz5cbiAgICA8Lz5cbiAgKSA6IG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICA8RGlzY2xhaW1lcldyYXBwZXIgcm9sZT1cInJlZ2lvblwiPlxuICAgICAgPFN0eWxlZE1lc3NhZ2VCb3ggdHlwZT1cImluZm9cIiBjb250ZW50RWRpdGFibGU9e2ZhbHNlfT5cbiAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZSAvPlxuICAgICAgICA8RGlzY2xhaW1lcj5cbiAgICAgICAgICB7ZW1iZWREYXRhLmRpc2NsYWltZXJ9XG4gICAgICAgICAge2Rpc2NsYWltZXJMaW5rfVxuICAgICAgICA8L0Rpc2NsYWltZXI+XG4gICAgICA8L1N0eWxlZE1lc3NhZ2VCb3g+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9EaXNjbGFpbWVyV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFV1RGlzY2xhaW1lckVtYmVkO1xuIl19 */"));
41
33
  const DisclaimerWrapper = /*#__PURE__*/_styled("div", {
42
34
  target: "e1pgbrp20",
43
35
  label: "DisclaimerWrapper"
44
- })(">:nth-child(2){margin-top:", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ29DIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgSW5mb3JtYXRpb25PdXRsaW5lIH0gZnJvbSBcIkBuZGxhL2ljb25zL2NvbW1vblwiO1xuaW1wb3J0IHsgU2FmZUxpbmsgfSBmcm9tIFwiQG5kbGEvc2FmZWxpbmtcIjtcbmltcG9ydCB7IFV1RGlzY2xhaW1lck1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBNZXNzYWdlQm94IH0gZnJvbSBcIi4uL01lc3NhZ2VzXCI7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogVXVEaXNjbGFpbWVyTWV0YURhdGE7XG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBTdHlsZWRNZXNzYWdlQm94ID0gc3R5bGVkKE1lc3NhZ2VCb3gpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxvdztcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC13ZWJraXQtdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tb3otdXNlci1zZWxlY3Q6IG5vbmU7XG4gIC1tcy11c2VyLXNlbGVjdDogbm9uZTtcbmA7XG5cbmNvbnN0IERpc2NsYWltZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgPiA6bnRoLWNoaWxkKDIpIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcueHNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgVXVEaXNjbGFpbWVyRW1iZWQgPSAoeyBlbWJlZCwgY2hpbGRyZW4gfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuXG4gIGlmIChlbWJlZC5zdGF0dXMgPT09IFwiZXJyb3JcIikge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgeyBlbWJlZERhdGEsIGRhdGEgfSA9IGVtYmVkO1xuXG4gIGNvbnN0IGRpc2NsYWltZXJMaW5rID0gZGF0YT8uZGlzY2xhaW1lckxpbmsgPyAoXG4gICAgPD5cbiAgICAgIHtgICR7dChcInV1RGlzY2xhaW1lci5hbHRlcm5hdGl2ZVwiKX0gYH1cbiAgICAgIDxTYWZlTGluayB0bz17ZGF0YS5kaXNjbGFpbWVyTGluay5ocmVmfSB0YXJnZXQ9XCJfYmxhbmtcIiByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCI+XG4gICAgICAgIHtkYXRhLmRpc2NsYWltZXJMaW5rLnRleHR9XG4gICAgICA8L1NhZmVMaW5rPlxuICAgIDwvPlxuICApIDogbnVsbDtcblxuICByZXR1cm4gKFxuICAgIDxEaXNjbGFpbWVyV3JhcHBlciByb2xlPVwicmVnaW9uXCI+XG4gICAgICA8U3R5bGVkTWVzc2FnZUJveCB0eXBlPVwiaW5mb1wiIGNvbnRlbnRFZGl0YWJsZT17ZmFsc2V9PlxuICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lIC8+XG4gICAgICAgIDxEaXNjbGFpbWVyPlxuICAgICAgICAgIHtlbWJlZERhdGEuZGlzY2xhaW1lcn1cbiAgICAgICAgICB7ZGlzY2xhaW1lckxpbmt9XG4gICAgICAgIDwvRGlzY2xhaW1lcj5cbiAgICAgIDwvU3R5bGVkTWVzc2FnZUJveD5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0Rpc2NsYWltZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgVXVEaXNjbGFpbWVyRW1iZWQ7XG4iXX0= */"));
36
+ })(">:nth-child(2){margin-top:", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlV1RGlzY2xhaW1lckVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ29DIiwiZmlsZSI6IlV1RGlzY2xhaW1lckVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGZvbnRzLCBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEluZm9ybWF0aW9uT3V0bGluZSB9IGZyb20gXCJAbmRsYS9pY29ucy9jb21tb25cIjtcbmltcG9ydCB7IFNhZmVMaW5rIH0gZnJvbSBcIkBuZGxhL3NhZmVsaW5rXCI7XG5pbXBvcnQgeyBVdURpc2NsYWltZXJNZXRhRGF0YSB9IGZyb20gXCJAbmRsYS90eXBlcy1lbWJlZFwiO1xuaW1wb3J0IHsgTWVzc2FnZUJveCB9IGZyb20gXCIuLi9NZXNzYWdlc1wiO1xuaW50ZXJmYWNlIFByb3BzIHtcbiAgZW1iZWQ6IFV1RGlzY2xhaW1lck1ldGFEYXRhO1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgU3R5bGVkTWVzc2FnZUJveCA9IHN0eWxlZChNZXNzYWdlQm94KWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1hbGlnbjogY2VudGVyO1xuYDtcblxuY29uc3QgRGlzY2xhaW1lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsb3c7XG4gICR7Zm9udHMuc2l6ZXMoXCIxOHB4XCIsIFwiMjRweFwiKX07XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICAtd2Via2l0LXVzZXItc2VsZWN0OiBub25lO1xuICAtbW96LXVzZXItc2VsZWN0OiBub25lO1xuICAtbXMtdXNlci1zZWxlY3Q6IG5vbmU7XG5gO1xuXG5jb25zdCBEaXNjbGFpbWVyV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gID4gOm50aC1jaGlsZCgyKSB7XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IFV1RGlzY2xhaW1lckVtYmVkID0gKHsgZW1iZWQsIGNoaWxkcmVuIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICBpZiAoZW1iZWQuc3RhdHVzID09PSBcImVycm9yXCIpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcblxuICBjb25zdCBkaXNjbGFpbWVyTGluayA9IGRhdGE/LmRpc2NsYWltZXJMaW5rID8gKFxuICAgIDw+XG4gICAgICB7YCAke3QoXCJ1dURpc2NsYWltZXIuYWx0ZXJuYXRpdmVcIil9IGB9XG4gICAgICA8U2FmZUxpbmsgdG89e2RhdGEuZGlzY2xhaW1lckxpbmsuaHJlZn0gdGFyZ2V0PVwiX2JsYW5rXCIgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiPlxuICAgICAgICB7ZGF0YS5kaXNjbGFpbWVyTGluay50ZXh0fVxuICAgICAgPC9TYWZlTGluaz5cbiAgICA8Lz5cbiAgKSA6IG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICA8RGlzY2xhaW1lcldyYXBwZXIgcm9sZT1cInJlZ2lvblwiPlxuICAgICAgPFN0eWxlZE1lc3NhZ2VCb3ggdHlwZT1cImluZm9cIiBjb250ZW50RWRpdGFibGU9e2ZhbHNlfT5cbiAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZSAvPlxuICAgICAgICA8RGlzY2xhaW1lcj5cbiAgICAgICAgICB7ZW1iZWREYXRhLmRpc2NsYWltZXJ9XG4gICAgICAgICAge2Rpc2NsYWltZXJMaW5rfVxuICAgICAgICA8L0Rpc2NsYWltZXI+XG4gICAgICA8L1N0eWxlZE1lc3NhZ2VCb3g+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9EaXNjbGFpbWVyV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFV1RGlzY2xhaW1lckVtYmVkO1xuIl19 */"));
45
37
  const UuDisclaimerEmbed = _ref => {
46
38
  let {
47
39
  embed,