@ndla/ui 55.0.6-alpha.0 → 55.0.8-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -87,7 +87,7 @@ const expandedSizes = "(min-width: 1024px) 1024px, 100vw";
87
87
  const StyledFigure = /*#__PURE__*/_styled(Figure, {
88
88
  target: "ened8ka2",
89
89
  label: "StyledFigure"
90
- })("&:hover{[data-byline-button]{background:", colors.white, ";}button[data-expanded]{transform:scale(1.2);}}button[data-expanded=\"true\"]{svg{transform:rotate(-45deg);}}&[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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.mediumlarge};\n  height: ${spacing.mediumlarge};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.medium};\n    width: ${spacing.medium};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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, ";}button[data-expanded]{transform:scale(1.2);}}button[data-expanded=\"true\"]{svg{transform:rotate(-45deg);}}&[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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.normal};\n  height: ${spacing.normal};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.nsmall};\n    width: ${spacing.nsmall};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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,
@@ -182,11 +182,11 @@ const hideByline = embed => {
182
182
  const BylineButton = /*#__PURE__*/_styled("button", {
183
183
  target: "ened8ka1",
184
184
  label: "BylineButton"
185
- })("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":"AAyOkC","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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.mediumlarge};\n  height: ${spacing.mediumlarge};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.medium};\n    width: ${spacing.medium};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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"]} */"));
185
+ })("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":"AAyOkC","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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.normal};\n  height: ${spacing.normal};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.nsmall};\n    width: ${spacing.nsmall};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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"]} */"));
186
186
  const StyledButton = /*#__PURE__*/_styled("button", {
187
187
  target: "ened8ka0",
188
188
  label: "StyledButton"
189
- })("display:flex;align-items:center;justify-content:center;cursor:pointer;position:absolute;padding:0;top:", spacing.small, ";right:", spacing.small, ";width:", spacing.mediumlarge, ";height:", spacing.mediumlarge, ";border:2px solid ", colors.white, ";transition:all 0.3s ease-out;color:", colors.white, ";background-color:", colors.brand.primary, ";border-radius:", misc.borderRadiusLarge, ";svg{transition:transform 0.4s ease-out;height:", spacing.medium, ";width:", spacing.medium, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AA4PkC","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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.mediumlarge};\n  height: ${spacing.mediumlarge};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.medium};\n    width: ${spacing.medium};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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"]} */"));
189
+ })("display:flex;align-items:center;justify-content:center;cursor:pointer;position:absolute;padding:0;top:", spacing.small, ";right:", spacing.small, ";width:", spacing.normal, ";height:", spacing.normal, ";border:2px solid ", colors.white, ";transition:all 0.3s ease-out;color:", colors.white, ";background-color:", colors.brand.primary, ";border-radius:", misc.borderRadiusLarge, ";svg{transition:transform 0.4s ease-out;height:", spacing.nsmall, ";width:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AA4PkC","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, misc, spacing } from \"@ndla/core\";\nimport { Plus } from \"@ndla/icons/action\";\nimport { 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 } 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    }\n    button[data-expanded] {\n      transform: scale(1.2);\n    }\n  }\n  button[data-expanded=\"true\"] {\n    svg {\n      transform: rotate(-45deg);\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  const toggleImageSize = () => {\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\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        onExpand={isAlign(embedData.align) ? toggleImageSize : undefined}\n        expanded={!!imageSizes}\n        expandButton={\n          <ExpandButton\n            embedData={embedData}\n            expanded={!!imageSizes}\n            align={embedData.align}\n            bylineHidden={isBylineHidden}\n            onExpand={toggleImageSize}\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  align?: string;\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 StyledButton = styled.button`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  cursor: pointer;\n  position: absolute;\n  padding: 0;\n  top: ${spacing.small};\n  right: ${spacing.small};\n  width: ${spacing.normal};\n  height: ${spacing.normal};\n  border: 2px solid ${colors.white};\n  transition: all 0.3s ease-out;\n  color: ${colors.white};\n  background-color: ${colors.brand.primary};\n  border-radius: ${misc.borderRadiusLarge};\n  svg {\n    transition: transform 0.4s ease-out;\n    height: ${spacing.nsmall};\n    width: ${spacing.nsmall};\n  }\n`;\n\nconst ExpandButton = ({ align, embedData, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isAlign(align)) {\n    return (\n      <StyledButton\n        type=\"button\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? \"Out\" : \"\"}ImageButtonLabel`)}\n        onClick={onExpand}\n        data-expanded={expanded}\n      >\n        <Plus />\n      </StyledButton>\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"]} */"));
190
190
  const ExpandButton = _ref2 => {
191
191
  let {
192
192
  align,
@@ -16,7 +16,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
16
16
  const StyledLogInIconWrapper = /*#__PURE__*/_styled("span", {
17
17
  target: "e1a7kjll0",
18
18
  label: "StyledLogInIconWrapper"
19
- })("margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVycm9yUmVzb3VyY2VBY2Nlc3NEZW5pZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCMEMiLCJmaWxlIjoiRXJyb3JSZXNvdXJjZUFjY2Vzc0RlbmllZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tIFwiQG5kbGEvYnV0dG9uXCI7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEh1bWFuTWFsZUJvYXJkLCBMb2dJbiB9IGZyb20gXCJAbmRsYS9pY29ucy9jb21tb25cIjtcblxuaW1wb3J0IEVycm9yTWVzc2FnZSBmcm9tIFwiLi9FcnJvck1lc3NhZ2VcIjtcblxuY29uc3QgU3R5bGVkTG9nSW5JY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG50eXBlIFByb3BzID0ge1xuICBvbkF1dGhlbnRpY2F0ZUNsaWNrOiAoKSA9PiB2b2lkO1xufTtcbmNvbnN0IEVycm9yUmVzb3VyY2VBY2Nlc3NEZW5pZWQgPSAoeyBvbkF1dGhlbnRpY2F0ZUNsaWNrIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RXJyb3JNZXNzYWdlXG4gICAgICBtZXNzYWdlcz17e1xuICAgICAgICB0aXRsZTogdChcInVzZXIucmVzb3VyY2UuYWNjZXNzRGVuaWVkXCIpLFxuICAgICAgICBiYWNrOiB0KFwiZXJyb3JNZXNzYWdlLmJhY2tcIiksXG4gICAgICAgIGdvVG9Gcm9udFBhZ2U6IHQoXCJlcnJvck1lc3NhZ2UuZ29Ub0Zyb250UGFnZVwiKSxcbiAgICAgIH19XG4gICAgICBpbGx1c3RyYXRpb25FbGVtZW50PXs8SHVtYW5NYWxlQm9hcmQgc2l6ZT1cImxhcmdlXCIgLz59XG4gICAgICBjdXN0b21FbGVtZW50PXtcbiAgICAgICAgPEJ1dHRvblYyIHNpemU9XCJtZWRpdW1cIiBvbkNsaWNrPXtvbkF1dGhlbnRpY2F0ZUNsaWNrfT5cbiAgICAgICAgICB7dChcInVzZXIuYnV0dG9uTG9nSW5cIil9XG4gICAgICAgICAgPFN0eWxlZExvZ0luSWNvbldyYXBwZXIgYXJpYS1oaWRkZW4+XG4gICAgICAgICAgICA8TG9nSW4gc2l6ZT1cIm5vcm1hbFwiIC8+XG4gICAgICAgICAgPC9TdHlsZWRMb2dJbkljb25XcmFwcGVyPlxuICAgICAgICA8L0J1dHRvblYyPlxuICAgICAgfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBFcnJvclJlc291cmNlQWNjZXNzRGVuaWVkO1xuIl19 */"));
19
+ })("margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVycm9yUmVzb3VyY2VBY2Nlc3NEZW5pZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCMEMiLCJmaWxlIjoiRXJyb3JSZXNvdXJjZUFjY2Vzc0RlbmllZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tIFwiQG5kbGEvYnV0dG9uXCI7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEh1bWFuTWFsZUJvYXJkLCBMb2dJbiB9IGZyb20gXCJAbmRsYS9pY29ucy9jb21tb25cIjtcblxuaW1wb3J0IEVycm9yTWVzc2FnZSBmcm9tIFwiLi9FcnJvck1lc3NhZ2VcIjtcblxuY29uc3QgU3R5bGVkTG9nSW5JY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnhzbWFsbH07XG5gO1xuXG50eXBlIFByb3BzID0ge1xuICBvbkF1dGhlbnRpY2F0ZUNsaWNrOiAoKSA9PiB2b2lkO1xufTtcbmNvbnN0IEVycm9yUmVzb3VyY2VBY2Nlc3NEZW5pZWQgPSAoeyBvbkF1dGhlbnRpY2F0ZUNsaWNrIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RXJyb3JNZXNzYWdlXG4gICAgICBtZXNzYWdlcz17e1xuICAgICAgICB0aXRsZTogdChcInVzZXIucmVzb3VyY2UuYWNjZXNzRGVuaWVkXCIpLFxuICAgICAgICBiYWNrOiB0KFwiZXJyb3JNZXNzYWdlLmJhY2tcIiksXG4gICAgICAgIGdvVG9Gcm9udFBhZ2U6IHQoXCJlcnJvck1lc3NhZ2UuZ29Ub0Zyb250UGFnZVwiKSxcbiAgICAgIH19XG4gICAgICBpbGx1c3RyYXRpb25FbGVtZW50PXs8SHVtYW5NYWxlQm9hcmQgc2l6ZT1cIm1lZGl1bVwiIC8+fVxuICAgICAgY3VzdG9tRWxlbWVudD17XG4gICAgICAgIDxCdXR0b25WMiBzaXplPVwibWVkaXVtXCIgb25DbGljaz17b25BdXRoZW50aWNhdGVDbGlja30+XG4gICAgICAgICAge3QoXCJ1c2VyLmJ1dHRvbkxvZ0luXCIpfVxuICAgICAgICAgIDxTdHlsZWRMb2dJbkljb25XcmFwcGVyIGFyaWEtaGlkZGVuPlxuICAgICAgICAgICAgPExvZ0luIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgIDwvU3R5bGVkTG9nSW5JY29uV3JhcHBlcj5cbiAgICAgICAgPC9CdXR0b25WMj5cbiAgICAgIH1cbiAgICAvPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRXJyb3JSZXNvdXJjZUFjY2Vzc0RlbmllZDtcbiJdfQ== */"));
20
20
  const ErrorResourceAccessDenied = _ref => {
21
21
  let {
22
22
  onAuthenticateClick
@@ -31,7 +31,7 @@ const ErrorResourceAccessDenied = _ref => {
31
31
  goToFrontPage: t("errorMessage.goToFrontPage")
32
32
  },
33
33
  illustrationElement: _jsx(HumanMaleBoard, {
34
- size: "large"
34
+ size: "medium"
35
35
  }),
36
36
  customElement: _jsxs(ButtonV2, {
37
37
  size: "medium",
@@ -39,7 +39,7 @@ const ErrorResourceAccessDenied = _ref => {
39
39
  children: [t("user.buttonLogIn"), _jsx(StyledLogInIconWrapper, {
40
40
  "aria-hidden": true,
41
41
  children: _jsx(LogIn, {
42
- size: "normal"
42
+ size: "medium"
43
43
  })
44
44
  })]
45
45
  })
@@ -6,5 +6,4 @@
6
6
  *
7
7
  */
8
8
 
9
- export { default as Figure } from "./Figure";
10
- export { figureActionIndicatorStyle } from "./figureActionIndicatorStyle";
9
+ export { default as Figure } from "./Figure";
@@ -9,28 +9,28 @@ import _styled from "@emotion/styled/base";
9
9
 
10
10
  /** @jsxImportSource @emotion/react */
11
11
  import { useTranslation } from "react-i18next";
12
- import { animations, breakpoints, colors, mq, spacing } from "@ndla/core";
12
+ import { animations, breakpoints, colors, misc, mq, spacing } from "@ndla/core";
13
13
  import { ExpandTwoArrows, CursorClick } from "@ndla/icons/action";
14
14
  import { Play } from "@ndla/icons/common";
15
- import { Figure, figureActionIndicatorStyle } from "../Figure";
15
+ import { Figure } from "../Figure";
16
16
  import Image from "../Image";
17
17
  import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
18
18
  const StyledImageWrapper = /*#__PURE__*/_styled("div", {
19
- target: "e1beccco2",
19
+ target: "e1beccco3",
20
20
  label: "StyledImageWrapper"
21
21
  })("overflow:hidden;width:260px;padding-top:", spacing.small, ";", mq.range({
22
22
  until: breakpoints.tabletWide
23
- }), "{margin:0 auto;}&:hover{img{transform:scale(1.1);opacity:1.1;transition-duration:0.5s;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnFDIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUsIGZpZ3VyZUFjdGlvbkluZGljYXRvclN0eWxlIH0gZnJvbSBcIi4uL0ZpZ3VyZVwiO1xuaW1wb3J0IEltYWdlIGZyb20gXCIuLi9JbWFnZVwiO1xuXG5jb25zdCBTdHlsZWRJbWFnZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBvdmVyZmxvdzogaGlkZGVuO1xuICB3aWR0aDogMjYwcHg7XG4gIHBhZGRpbmctdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtYXJnaW46IDAgYXV0bztcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBpbWcge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICAgICAgb3BhY2l0eTogMS4xO1xuICAgICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogMC41cztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltYWdlID0gc3R5bGVkKEltYWdlKWBcbiAgb2JqZWN0LWZpdDogY292ZXI7XG4gIG1heC1oZWlnaHQ6IDE2MnB4O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHthbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0fTtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbWluLXdpZHRoOiAyNjBweDtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdHlwZTogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCIgfCB1bmRlZmluZWQ7XG4gIHNyYzogc3RyaW5nO1xuICBhbHQ6IHN0cmluZztcbn1cblxuY29uc3QgU3R5bGVkRmlndXJlID0gc3R5bGVkKEZpZ3VyZSlgXG4gICY6aG92ZXIge1xuICAgIFtkYXRhLW9wZW4tYnV0dG9uXSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy53aGl0ZX07XG4gICAgICBzdmcge1xuICAgICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgTm90aW9uSW1hZ2UgPSAoeyBzcmMsIGFsdCwgdHlwZSB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRGaWd1cmUgdHlwZT17XCJmdWxsLWNvbHVtblwifT5cbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxTdHlsZWRJbWFnZSBhbHQ9e2FsdH0gc3JjPXtzcmN9IGV4cGFuZEJ1dHRvbj17PE9wZW5CdXR0b24gdHlwZT17dHlwZX0gLz59IC8+XG4gICAgICA8L1N0eWxlZEltYWdlV3JhcHBlcj5cbiAgICA8L1N0eWxlZEZpZ3VyZT5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBPcGVuQnV0dG9uUHJvcHMge1xuICB0eXBlPzogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCI7XG59XG5cbmV4cG9ydCBjb25zdCBPcGVuQnV0dG9uID0gKHsgdHlwZSB9OiBPcGVuQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17ZmlndXJlQWN0aW9uSW5kaWNhdG9yU3R5bGV9XG4gICAgICBkYXRhLW9wZW4tYnV0dG9uPVwiXCJcbiAgICAgIGFyaWEtbGFiZWw9e3QoXCJsaWNlbnNlLmltYWdlcy5pdGVtSW1hZ2Uuem9vbUltYWdlQnV0dG9uTGFiZWxcIil9XG4gICAgPlxuICAgICAge3R5cGUgPT09IFwiaW1hZ2VcIiAmJiA8RXhwYW5kVHdvQXJyb3dzIC8+fVxuICAgICAge3R5cGUgPT09IFwiaDVwXCIgJiYgPEN1cnNvckNsaWNrIHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICAgIHt0eXBlID09PSBcImlmcmFtZVwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJleHRlcm5hbFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJ2aWRlb1wiICYmIDxQbGF5IHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG4iXX0= */"));
23
+ }), "{margin:0 auto;}&:hover{img{transform:scale(1.1);opacity:1.1;transition-duration:0.5s;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnFDIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tIFwiLi4vRmlndXJlXCI7XG5pbXBvcnQgSW1hZ2UgZnJvbSBcIi4uL0ltYWdlXCI7XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHdpZHRoOiAyNjBweDtcbiAgcGFkZGluZy10b3A6ICR7c3BhY2luZy5zbWFsbH07XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMCBhdXRvO1xuICB9XG4gICY6aG92ZXIge1xuICAgIGltZyB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMSk7XG4gICAgICBvcGFjaXR5OiAxLjE7XG4gICAgICB0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjVzO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkSW1hZ2UgPSBzdHlsZWQoSW1hZ2UpYFxuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LWhlaWdodDogMTYycHg7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAke2FuaW1hdGlvbnMuZHVyYXRpb25zLmZhc3R9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtaW4td2lkdGg6IDI2MHB4O1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0eXBlOiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIiB8IHVuZGVmaW5lZDtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRGaWd1cmUgPSBzdHlsZWQoRmlndXJlKWBcbiAgJjpob3ZlciB7XG4gICAgW2RhdGEtb3Blbi1idXR0b25dIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLndoaXRlfTtcbiAgICAgIHN2ZyB7XG4gICAgICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOb3Rpb25JbWFnZSA9ICh7IHNyYywgYWx0LCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEZpZ3VyZSB0eXBlPXtcImZ1bGwtY29sdW1uXCJ9PlxuICAgICAgPFN0eWxlZEltYWdlV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZEltYWdlIGFsdD17YWx0fSBzcmM9e3NyY30gZXhwYW5kQnV0dG9uPXs8T3BlbkJ1dHRvbiB0eXBlPXt0eXBlfSAvPn0gLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgIDwvU3R5bGVkRmlndXJlPlxuICApO1xufTtcblxuaW50ZXJmYWNlIE9wZW5CdXR0b25Qcm9wcyB7XG4gIHR5cGU/OiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIjtcbn1cblxuZXhwb3J0IGNvbnN0IEZpZ3VyZUFjdGlvbkluZGljYXRvciA9IHN0eWxlZC5kaXZgXG4gIGFsbDogdW5zZXQ7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBwYWRkaW5nOiAwO1xuICBib3R0b206IDhweDtcbiAgcmlnaHQ6IDhweDtcbiAgd2lkdGg6IDQwcHg7XG4gIGhlaWdodDogNDBweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAwLjNzIGVhc2Utb3V0O1xuICAvLyBUaGUgNjUgaXMgYWRkZWQgdG8gYWx0ZXIgdGhlIG9wYWNpdHkuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmJhY2tncm91bmQuZGVmYXVsdH02NTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c0xhcmdlfTtcbiAgYm9yZGVyOiAwO1xuICBzdmcge1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjRzIGVhc2Utb3V0O1xuICAgIHdpZHRoOiAxOHB4O1xuICAgIGhlaWdodDogMThweDtcbiAgICBmaWxsOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IHR5cGUgfTogT3BlbkJ1dHRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RmlndXJlQWN0aW9uSW5kaWNhdG9yIGRhdGEtb3Blbi1idXR0b249XCJcIiBhcmlhLWxhYmVsPXt0KFwibGljZW5zZS5pbWFnZXMuaXRlbUltYWdlLnpvb21JbWFnZUJ1dHRvbkxhYmVsXCIpfT5cbiAgICAgIHt0eXBlID09PSBcImltYWdlXCIgJiYgPEV4cGFuZFR3b0Fycm93cyAvPn1cbiAgICAgIHt0eXBlID09PSBcImg1cFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJpZnJhbWVcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwiZXh0ZXJuYWxcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwidmlkZW9cIiAmJiA8UGxheSBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgPC9GaWd1cmVBY3Rpb25JbmRpY2F0b3I+XG4gICk7XG59O1xuIl19 */"));
24
24
  const StyledImage = /*#__PURE__*/_styled(Image, {
25
- target: "e1beccco1",
25
+ target: "e1beccco2",
26
26
  label: "StyledImage"
27
27
  })("object-fit:cover;max-height:162px;transition:transform ", animations.durations.fast, ";", mq.range({
28
28
  until: breakpoints.tabletWide
29
- }), "{min-width:260px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ2lDIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUsIGZpZ3VyZUFjdGlvbkluZGljYXRvclN0eWxlIH0gZnJvbSBcIi4uL0ZpZ3VyZVwiO1xuaW1wb3J0IEltYWdlIGZyb20gXCIuLi9JbWFnZVwiO1xuXG5jb25zdCBTdHlsZWRJbWFnZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBvdmVyZmxvdzogaGlkZGVuO1xuICB3aWR0aDogMjYwcHg7XG4gIHBhZGRpbmctdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtYXJnaW46IDAgYXV0bztcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBpbWcge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICAgICAgb3BhY2l0eTogMS4xO1xuICAgICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogMC41cztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltYWdlID0gc3R5bGVkKEltYWdlKWBcbiAgb2JqZWN0LWZpdDogY292ZXI7XG4gIG1heC1oZWlnaHQ6IDE2MnB4O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHthbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0fTtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbWluLXdpZHRoOiAyNjBweDtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdHlwZTogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCIgfCB1bmRlZmluZWQ7XG4gIHNyYzogc3RyaW5nO1xuICBhbHQ6IHN0cmluZztcbn1cblxuY29uc3QgU3R5bGVkRmlndXJlID0gc3R5bGVkKEZpZ3VyZSlgXG4gICY6aG92ZXIge1xuICAgIFtkYXRhLW9wZW4tYnV0dG9uXSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy53aGl0ZX07XG4gICAgICBzdmcge1xuICAgICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgTm90aW9uSW1hZ2UgPSAoeyBzcmMsIGFsdCwgdHlwZSB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRGaWd1cmUgdHlwZT17XCJmdWxsLWNvbHVtblwifT5cbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxTdHlsZWRJbWFnZSBhbHQ9e2FsdH0gc3JjPXtzcmN9IGV4cGFuZEJ1dHRvbj17PE9wZW5CdXR0b24gdHlwZT17dHlwZX0gLz59IC8+XG4gICAgICA8L1N0eWxlZEltYWdlV3JhcHBlcj5cbiAgICA8L1N0eWxlZEZpZ3VyZT5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBPcGVuQnV0dG9uUHJvcHMge1xuICB0eXBlPzogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCI7XG59XG5cbmV4cG9ydCBjb25zdCBPcGVuQnV0dG9uID0gKHsgdHlwZSB9OiBPcGVuQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17ZmlndXJlQWN0aW9uSW5kaWNhdG9yU3R5bGV9XG4gICAgICBkYXRhLW9wZW4tYnV0dG9uPVwiXCJcbiAgICAgIGFyaWEtbGFiZWw9e3QoXCJsaWNlbnNlLmltYWdlcy5pdGVtSW1hZ2Uuem9vbUltYWdlQnV0dG9uTGFiZWxcIil9XG4gICAgPlxuICAgICAge3R5cGUgPT09IFwiaW1hZ2VcIiAmJiA8RXhwYW5kVHdvQXJyb3dzIC8+fVxuICAgICAge3R5cGUgPT09IFwiaDVwXCIgJiYgPEN1cnNvckNsaWNrIHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICAgIHt0eXBlID09PSBcImlmcmFtZVwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJleHRlcm5hbFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJ2aWRlb1wiICYmIDxQbGF5IHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG4iXX0= */"));
29
+ }), "{min-width:260px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ2lDIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tIFwiLi4vRmlndXJlXCI7XG5pbXBvcnQgSW1hZ2UgZnJvbSBcIi4uL0ltYWdlXCI7XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHdpZHRoOiAyNjBweDtcbiAgcGFkZGluZy10b3A6ICR7c3BhY2luZy5zbWFsbH07XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMCBhdXRvO1xuICB9XG4gICY6aG92ZXIge1xuICAgIGltZyB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMSk7XG4gICAgICBvcGFjaXR5OiAxLjE7XG4gICAgICB0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjVzO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkSW1hZ2UgPSBzdHlsZWQoSW1hZ2UpYFxuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LWhlaWdodDogMTYycHg7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAke2FuaW1hdGlvbnMuZHVyYXRpb25zLmZhc3R9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtaW4td2lkdGg6IDI2MHB4O1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0eXBlOiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIiB8IHVuZGVmaW5lZDtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRGaWd1cmUgPSBzdHlsZWQoRmlndXJlKWBcbiAgJjpob3ZlciB7XG4gICAgW2RhdGEtb3Blbi1idXR0b25dIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLndoaXRlfTtcbiAgICAgIHN2ZyB7XG4gICAgICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOb3Rpb25JbWFnZSA9ICh7IHNyYywgYWx0LCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEZpZ3VyZSB0eXBlPXtcImZ1bGwtY29sdW1uXCJ9PlxuICAgICAgPFN0eWxlZEltYWdlV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZEltYWdlIGFsdD17YWx0fSBzcmM9e3NyY30gZXhwYW5kQnV0dG9uPXs8T3BlbkJ1dHRvbiB0eXBlPXt0eXBlfSAvPn0gLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgIDwvU3R5bGVkRmlndXJlPlxuICApO1xufTtcblxuaW50ZXJmYWNlIE9wZW5CdXR0b25Qcm9wcyB7XG4gIHR5cGU/OiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIjtcbn1cblxuZXhwb3J0IGNvbnN0IEZpZ3VyZUFjdGlvbkluZGljYXRvciA9IHN0eWxlZC5kaXZgXG4gIGFsbDogdW5zZXQ7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBwYWRkaW5nOiAwO1xuICBib3R0b206IDhweDtcbiAgcmlnaHQ6IDhweDtcbiAgd2lkdGg6IDQwcHg7XG4gIGhlaWdodDogNDBweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAwLjNzIGVhc2Utb3V0O1xuICAvLyBUaGUgNjUgaXMgYWRkZWQgdG8gYWx0ZXIgdGhlIG9wYWNpdHkuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmJhY2tncm91bmQuZGVmYXVsdH02NTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c0xhcmdlfTtcbiAgYm9yZGVyOiAwO1xuICBzdmcge1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjRzIGVhc2Utb3V0O1xuICAgIHdpZHRoOiAxOHB4O1xuICAgIGhlaWdodDogMThweDtcbiAgICBmaWxsOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IHR5cGUgfTogT3BlbkJ1dHRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RmlndXJlQWN0aW9uSW5kaWNhdG9yIGRhdGEtb3Blbi1idXR0b249XCJcIiBhcmlhLWxhYmVsPXt0KFwibGljZW5zZS5pbWFnZXMuaXRlbUltYWdlLnpvb21JbWFnZUJ1dHRvbkxhYmVsXCIpfT5cbiAgICAgIHt0eXBlID09PSBcImltYWdlXCIgJiYgPEV4cGFuZFR3b0Fycm93cyAvPn1cbiAgICAgIHt0eXBlID09PSBcImg1cFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJpZnJhbWVcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwiZXh0ZXJuYWxcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwidmlkZW9cIiAmJiA8UGxheSBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgPC9GaWd1cmVBY3Rpb25JbmRpY2F0b3I+XG4gICk7XG59O1xuIl19 */"));
30
30
  const StyledFigure = /*#__PURE__*/_styled(Figure, {
31
- target: "e1beccco0",
31
+ target: "e1beccco1",
32
32
  label: "StyledFigure"
33
- })("&:hover{[data-open-button]{background:", colors.white, ";svg{transform:scale(1.2);}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRG1DIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUsIGZpZ3VyZUFjdGlvbkluZGljYXRvclN0eWxlIH0gZnJvbSBcIi4uL0ZpZ3VyZVwiO1xuaW1wb3J0IEltYWdlIGZyb20gXCIuLi9JbWFnZVwiO1xuXG5jb25zdCBTdHlsZWRJbWFnZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBvdmVyZmxvdzogaGlkZGVuO1xuICB3aWR0aDogMjYwcHg7XG4gIHBhZGRpbmctdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtYXJnaW46IDAgYXV0bztcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBpbWcge1xuICAgICAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICAgICAgb3BhY2l0eTogMS4xO1xuICAgICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogMC41cztcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltYWdlID0gc3R5bGVkKEltYWdlKWBcbiAgb2JqZWN0LWZpdDogY292ZXI7XG4gIG1heC1oZWlnaHQ6IDE2MnB4O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHthbmltYXRpb25zLmR1cmF0aW9ucy5mYXN0fTtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbWluLXdpZHRoOiAyNjBweDtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdHlwZTogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCIgfCB1bmRlZmluZWQ7XG4gIHNyYzogc3RyaW5nO1xuICBhbHQ6IHN0cmluZztcbn1cblxuY29uc3QgU3R5bGVkRmlndXJlID0gc3R5bGVkKEZpZ3VyZSlgXG4gICY6aG92ZXIge1xuICAgIFtkYXRhLW9wZW4tYnV0dG9uXSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy53aGl0ZX07XG4gICAgICBzdmcge1xuICAgICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgTm90aW9uSW1hZ2UgPSAoeyBzcmMsIGFsdCwgdHlwZSB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRGaWd1cmUgdHlwZT17XCJmdWxsLWNvbHVtblwifT5cbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxTdHlsZWRJbWFnZSBhbHQ9e2FsdH0gc3JjPXtzcmN9IGV4cGFuZEJ1dHRvbj17PE9wZW5CdXR0b24gdHlwZT17dHlwZX0gLz59IC8+XG4gICAgICA8L1N0eWxlZEltYWdlV3JhcHBlcj5cbiAgICA8L1N0eWxlZEZpZ3VyZT5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBPcGVuQnV0dG9uUHJvcHMge1xuICB0eXBlPzogXCJpbWFnZVwiIHwgXCJ2aWRlb1wiIHwgXCJoNXBcIiB8IFwiaWZyYW1lXCIgfCBcImV4dGVybmFsXCIgfCBcImF1ZGlvXCI7XG59XG5cbmV4cG9ydCBjb25zdCBPcGVuQnV0dG9uID0gKHsgdHlwZSB9OiBPcGVuQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17ZmlndXJlQWN0aW9uSW5kaWNhdG9yU3R5bGV9XG4gICAgICBkYXRhLW9wZW4tYnV0dG9uPVwiXCJcbiAgICAgIGFyaWEtbGFiZWw9e3QoXCJsaWNlbnNlLmltYWdlcy5pdGVtSW1hZ2Uuem9vbUltYWdlQnV0dG9uTGFiZWxcIil9XG4gICAgPlxuICAgICAge3R5cGUgPT09IFwiaW1hZ2VcIiAmJiA8RXhwYW5kVHdvQXJyb3dzIC8+fVxuICAgICAge3R5cGUgPT09IFwiaDVwXCIgJiYgPEN1cnNvckNsaWNrIHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICAgIHt0eXBlID09PSBcImlmcmFtZVwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJleHRlcm5hbFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJ2aWRlb1wiICYmIDxQbGF5IHN0eWxlPXt7IHdpZHRoOiBcIjI0cHhcIiwgaGVpZ2h0OiBcIjI0cHhcIiB9fSAvPn1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG4iXX0= */"));
33
+ })("&:hover{[data-open-button]{background:", colors.white, ";svg{transform:scale(1.2);}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRG1DIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tIFwiLi4vRmlndXJlXCI7XG5pbXBvcnQgSW1hZ2UgZnJvbSBcIi4uL0ltYWdlXCI7XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHdpZHRoOiAyNjBweDtcbiAgcGFkZGluZy10b3A6ICR7c3BhY2luZy5zbWFsbH07XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMCBhdXRvO1xuICB9XG4gICY6aG92ZXIge1xuICAgIGltZyB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMSk7XG4gICAgICBvcGFjaXR5OiAxLjE7XG4gICAgICB0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjVzO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkSW1hZ2UgPSBzdHlsZWQoSW1hZ2UpYFxuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LWhlaWdodDogMTYycHg7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAke2FuaW1hdGlvbnMuZHVyYXRpb25zLmZhc3R9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtaW4td2lkdGg6IDI2MHB4O1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0eXBlOiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIiB8IHVuZGVmaW5lZDtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRGaWd1cmUgPSBzdHlsZWQoRmlndXJlKWBcbiAgJjpob3ZlciB7XG4gICAgW2RhdGEtb3Blbi1idXR0b25dIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLndoaXRlfTtcbiAgICAgIHN2ZyB7XG4gICAgICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOb3Rpb25JbWFnZSA9ICh7IHNyYywgYWx0LCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEZpZ3VyZSB0eXBlPXtcImZ1bGwtY29sdW1uXCJ9PlxuICAgICAgPFN0eWxlZEltYWdlV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZEltYWdlIGFsdD17YWx0fSBzcmM9e3NyY30gZXhwYW5kQnV0dG9uPXs8T3BlbkJ1dHRvbiB0eXBlPXt0eXBlfSAvPn0gLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgIDwvU3R5bGVkRmlndXJlPlxuICApO1xufTtcblxuaW50ZXJmYWNlIE9wZW5CdXR0b25Qcm9wcyB7XG4gIHR5cGU/OiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIjtcbn1cblxuZXhwb3J0IGNvbnN0IEZpZ3VyZUFjdGlvbkluZGljYXRvciA9IHN0eWxlZC5kaXZgXG4gIGFsbDogdW5zZXQ7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBwYWRkaW5nOiAwO1xuICBib3R0b206IDhweDtcbiAgcmlnaHQ6IDhweDtcbiAgd2lkdGg6IDQwcHg7XG4gIGhlaWdodDogNDBweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAwLjNzIGVhc2Utb3V0O1xuICAvLyBUaGUgNjUgaXMgYWRkZWQgdG8gYWx0ZXIgdGhlIG9wYWNpdHkuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmJhY2tncm91bmQuZGVmYXVsdH02NTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c0xhcmdlfTtcbiAgYm9yZGVyOiAwO1xuICBzdmcge1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjRzIGVhc2Utb3V0O1xuICAgIHdpZHRoOiAxOHB4O1xuICAgIGhlaWdodDogMThweDtcbiAgICBmaWxsOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IHR5cGUgfTogT3BlbkJ1dHRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RmlndXJlQWN0aW9uSW5kaWNhdG9yIGRhdGEtb3Blbi1idXR0b249XCJcIiBhcmlhLWxhYmVsPXt0KFwibGljZW5zZS5pbWFnZXMuaXRlbUltYWdlLnpvb21JbWFnZUJ1dHRvbkxhYmVsXCIpfT5cbiAgICAgIHt0eXBlID09PSBcImltYWdlXCIgJiYgPEV4cGFuZFR3b0Fycm93cyAvPn1cbiAgICAgIHt0eXBlID09PSBcImg1cFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJpZnJhbWVcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwiZXh0ZXJuYWxcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwidmlkZW9cIiAmJiA8UGxheSBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgPC9GaWd1cmVBY3Rpb25JbmRpY2F0b3I+XG4gICk7XG59O1xuIl19 */"));
34
34
  export const NotionImage = _ref => {
35
35
  let {
36
36
  src,
@@ -50,6 +50,12 @@ export const NotionImage = _ref => {
50
50
  })
51
51
  });
52
52
  };
53
+ export const FigureActionIndicator = /*#__PURE__*/_styled("div", {
54
+ target: "e1beccco0",
55
+ label: "FigureActionIndicator"
56
+ })("all:unset;cursor:pointer;position:absolute;padding:0;bottom:8px;right:8px;width:40px;height:40px;display:flex;justify-content:center;align-items:center;transition:all 0.3s ease-out;background-color:", colors.background.default, "65;border-radius:", misc.borderRadiusLarge, ";border:0;svg{transition:transform 0.4s ease-out;width:18px;height:18px;fill:", colors.brand.primary, ";color:", colors.brand.primary, ";}", mq.range({
57
+ until: breakpoints.tablet
58
+ }), "{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RStDIiwiZmlsZSI6Ik5vdGlvbkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSBcInJlYWN0LWkxOG5leHRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tIFwiQG5kbGEvY29yZVwiO1xuaW1wb3J0IHsgRXhwYW5kVHdvQXJyb3dzLCBDdXJzb3JDbGljayB9IGZyb20gXCJAbmRsYS9pY29ucy9hY3Rpb25cIjtcbmltcG9ydCB7IFBsYXkgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tIFwiLi4vRmlndXJlXCI7XG5pbXBvcnQgSW1hZ2UgZnJvbSBcIi4uL0ltYWdlXCI7XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHdpZHRoOiAyNjBweDtcbiAgcGFkZGluZy10b3A6ICR7c3BhY2luZy5zbWFsbH07XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0V2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMCBhdXRvO1xuICB9XG4gICY6aG92ZXIge1xuICAgIGltZyB7XG4gICAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMSk7XG4gICAgICBvcGFjaXR5OiAxLjE7XG4gICAgICB0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjVzO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkSW1hZ2UgPSBzdHlsZWQoSW1hZ2UpYFxuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgbWF4LWhlaWdodDogMTYycHg7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAke2FuaW1hdGlvbnMuZHVyYXRpb25zLmZhc3R9O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBtaW4td2lkdGg6IDI2MHB4O1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0eXBlOiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIiB8IHVuZGVmaW5lZDtcbiAgc3JjOiBzdHJpbmc7XG4gIGFsdDogc3RyaW5nO1xufVxuXG5jb25zdCBTdHlsZWRGaWd1cmUgPSBzdHlsZWQoRmlndXJlKWBcbiAgJjpob3ZlciB7XG4gICAgW2RhdGEtb3Blbi1idXR0b25dIHtcbiAgICAgIGJhY2tncm91bmQ6ICR7Y29sb3JzLndoaXRlfTtcbiAgICAgIHN2ZyB7XG4gICAgICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOb3Rpb25JbWFnZSA9ICh7IHNyYywgYWx0LCB0eXBlIH06IFByb3BzKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEZpZ3VyZSB0eXBlPXtcImZ1bGwtY29sdW1uXCJ9PlxuICAgICAgPFN0eWxlZEltYWdlV3JhcHBlcj5cbiAgICAgICAgPFN0eWxlZEltYWdlIGFsdD17YWx0fSBzcmM9e3NyY30gZXhwYW5kQnV0dG9uPXs8T3BlbkJ1dHRvbiB0eXBlPXt0eXBlfSAvPn0gLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgIDwvU3R5bGVkRmlndXJlPlxuICApO1xufTtcblxuaW50ZXJmYWNlIE9wZW5CdXR0b25Qcm9wcyB7XG4gIHR5cGU/OiBcImltYWdlXCIgfCBcInZpZGVvXCIgfCBcImg1cFwiIHwgXCJpZnJhbWVcIiB8IFwiZXh0ZXJuYWxcIiB8IFwiYXVkaW9cIjtcbn1cblxuZXhwb3J0IGNvbnN0IEZpZ3VyZUFjdGlvbkluZGljYXRvciA9IHN0eWxlZC5kaXZgXG4gIGFsbDogdW5zZXQ7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBwYWRkaW5nOiAwO1xuICBib3R0b206IDhweDtcbiAgcmlnaHQ6IDhweDtcbiAgd2lkdGg6IDQwcHg7XG4gIGhlaWdodDogNDBweDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHRyYW5zaXRpb246IGFsbCAwLjNzIGVhc2Utb3V0O1xuICAvLyBUaGUgNjUgaXMgYWRkZWQgdG8gYWx0ZXIgdGhlIG9wYWNpdHkuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmJhY2tncm91bmQuZGVmYXVsdH02NTtcbiAgYm9yZGVyLXJhZGl1czogJHttaXNjLmJvcmRlclJhZGl1c0xhcmdlfTtcbiAgYm9yZGVyOiAwO1xuICBzdmcge1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjRzIGVhc2Utb3V0O1xuICAgIHdpZHRoOiAxOHB4O1xuICAgIGhlaWdodDogMThweDtcbiAgICBmaWxsOiAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQucHJpbWFyeX07XG4gIH1cbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgT3BlbkJ1dHRvbiA9ICh7IHR5cGUgfTogT3BlbkJ1dHRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8RmlndXJlQWN0aW9uSW5kaWNhdG9yIGRhdGEtb3Blbi1idXR0b249XCJcIiBhcmlhLWxhYmVsPXt0KFwibGljZW5zZS5pbWFnZXMuaXRlbUltYWdlLnpvb21JbWFnZUJ1dHRvbkxhYmVsXCIpfT5cbiAgICAgIHt0eXBlID09PSBcImltYWdlXCIgJiYgPEV4cGFuZFR3b0Fycm93cyAvPn1cbiAgICAgIHt0eXBlID09PSBcImg1cFwiICYmIDxDdXJzb3JDbGljayBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgICB7dHlwZSA9PT0gXCJpZnJhbWVcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwiZXh0ZXJuYWxcIiAmJiA8Q3Vyc29yQ2xpY2sgc3R5bGU9e3sgd2lkdGg6IFwiMjRweFwiLCBoZWlnaHQ6IFwiMjRweFwiIH19IC8+fVxuICAgICAge3R5cGUgPT09IFwidmlkZW9cIiAmJiA8UGxheSBzdHlsZT17eyB3aWR0aDogXCIyNHB4XCIsIGhlaWdodDogXCIyNHB4XCIgfX0gLz59XG4gICAgPC9GaWd1cmVBY3Rpb25JbmRpY2F0b3I+XG4gICk7XG59O1xuIl19 */"));
53
59
  export const OpenButton = _ref2 => {
54
60
  let {
55
61
  type
@@ -57,8 +63,7 @@ export const OpenButton = _ref2 => {
57
63
  const {
58
64
  t
59
65
  } = useTranslation();
60
- return _jsxs("div", {
61
- css: figureActionIndicatorStyle,
66
+ return _jsxs(FigureActionIndicator, {
62
67
  "data-open-button": "",
63
68
  "aria-label": t("license.images.itemImage.zoomImageButtonLabel"),
64
69
  children: [type === "image" && _jsx(ExpandTwoArrows, {}), type === "h5p" && _jsx(CursorClick, {
@@ -23,7 +23,7 @@ const renderAdditionalIcon = (label, isAdditional) => {
23
23
  tooltip: label,
24
24
  children: _jsx("div", {
25
25
  children: _jsx(Additional, {
26
- size: "normal",
26
+ size: "medium",
27
27
  "aria-hidden": false
28
28
  })
29
29
  })
@@ -31,7 +31,7 @@ const renderAdditionalIcon = (label, isAdditional) => {
31
31
  }
32
32
  if (isAdditional) {
33
33
  return _jsx(Additional, {
34
- size: "normal"
34
+ size: "medium"
35
35
  });
36
36
  }
37
37
  return null;
@@ -132,7 +132,7 @@ const ContentTypeResult = _ref => {
132
132
  children: _jsxs(ButtonV2, {
133
133
  variant: "ghost",
134
134
  shape: "pill",
135
- css: [showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle, ";label:ContentTypeResult;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeResult.tsx"],"names":[],"mappings":"AAqKgB","file":"ContentTypeResult.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { ReactElement, useEffect, useRef, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { Additional, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Tooltip } from \"@ndla/tooltip\";\nimport {\n  highlightStyle,\n  noWidthhighlightStyle,\n  showAllButtonStyle,\n  StyledHeader,\n  StyledList,\n  StyledListItem,\n  StyledNoHit,\n  StyledTag,\n  StyledWrapper,\n} from \"./ContentTypeResultStyles\";\nimport { isPathToHighlight } from \"./IsPathToHighlight\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport { ContentTypeResultType, Resource } from \"../types\";\n\nconst renderAdditionalIcon = (label: string, isAdditional?: boolean): ReactElement | null => {\n  if (isAdditional && label) {\n    return (\n      <Tooltip tooltip={label}>\n        <div>\n          <Additional size=\"normal\" aria-hidden={false} />\n        </div>\n      </Tooltip>\n    );\n  }\n  if (isAdditional) {\n    return <Additional size=\"normal\" />;\n  }\n  return null;\n};\n\ntype Props = {\n  contentTypeResult: ContentTypeResultType;\n  onNavigate?: VoidFunction;\n  defaultCount?: number;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  showAdditionalResources?: boolean;\n  messages: {\n    allResultLabel?: string;\n    showLessResultLabel?: string;\n    noHit: string;\n  };\n  ignoreContentTypeBadge?: boolean;\n  keyboardPathNavigation?: HTMLElement | string | null;\n  inMenu?: boolean;\n  animateList?: number;\n  unGrouped?: boolean;\n};\n\nconst ContentTypeResult = ({\n  contentTypeResult,\n  onNavigate,\n  defaultCount,\n  resourceToLinkProps,\n  showAdditionalResources,\n  messages,\n  ignoreContentTypeBadge,\n  keyboardPathNavigation,\n  inMenu,\n  animateList,\n  unGrouped,\n}: Props) => {\n  const { t } = useTranslation();\n  const [showAll, toggleShowAll] = useState(false);\n  const showAllRef = useRef<HTMLLIElement>(null);\n\n  const results =\n    showAdditionalResources || !contentTypeResult.resources\n      ? contentTypeResult.resources\n      : contentTypeResult.resources.filter((items) => !items.additional);\n\n  const resources = showAll || !defaultCount ? results : results.slice(0, defaultCount);\n\n  const displayShowAllButton = defaultCount && results.length > defaultCount;\n  const shouldHighlightShowAllButton = showAllRef.current === keyboardPathNavigation;\n\n  useEffect(() => {\n    if (showAll && showAllRef.current) {\n      showAllRef.current.scrollIntoView({\n        behavior: \"smooth\",\n        block: \"nearest\",\n      });\n    }\n  }, [showAll]);\n\n  return (\n    <StyledWrapper>\n      {!unGrouped && (\n        <StyledHeader>\n          {!ignoreContentTypeBadge && contentTypeResult.contentType && (\n            <ContentTypeBadge type={contentTypeResult.contentType} size=\"x-small\" background border />\n          )}\n          <h1>\n            {contentTypeResult.title} <small>({results.length})</small>\n          </h1>\n        </StyledHeader>\n      )}\n      {resources.length > 0 ? (\n        <StyledList inMenu={inMenu} animateList={animateList} unGrouped={unGrouped}>\n          {resources.map((resource) => {\n            const { path, name, resourceTypes, subject, additional } = resource;\n\n            const linkProps = resourceToLinkProps(resource);\n            const linkContent = (\n              <>\n                <strong>{name}</strong>\n                {!inMenu && subject && <small>{subject}</small>}\n                {!inMenu &&\n                  resourceTypes &&\n                  resourceTypes.map((type) => <StyledTag key={type.name}>{type.name}</StyledTag>)}\n              </>\n            );\n            const delayAnimation = !!animateList && !!additional && animateList > 0 && !!showAdditionalResources;\n\n            // Figure out highlighting by comparing path of link with keyboard navigated anchor\n            const anchor =\n              keyboardPathNavigation instanceof HTMLElement && keyboardPathNavigation\n                ? keyboardPathNavigation.querySelector(\"a\")\n                : undefined;\n            const anchorHref = anchor?.getAttribute(\"href\") ?? null;\n            const shouldHighlight = isPathToHighlight(path, anchorHref);\n\n            return (\n              <StyledListItem key={path} delayAnimation={delayAnimation}>\n                <SafeLink\n                  css={shouldHighlight && highlightStyle}\n                  data-highlighted={shouldHighlight || false}\n                  {...linkProps}\n                  onClick={() => {\n                    if (onNavigate) {\n                      onNavigate();\n                    }\n                  }}\n                >\n                  {unGrouped && !ignoreContentTypeBadge && (\n                    <ContentTypeBadge type={resource.contentType ?? \"\"} size=\"x-small\" background border />\n                  )}\n                  {linkContent}\n                  {renderAdditionalIcon(t(\"resource.additionalTooltip\"), additional)}\n                </SafeLink>\n              </StyledListItem>\n            );\n          })}\n          {displayShowAllButton && (\n            <StyledListItem ref={showAllRef}>\n              <ButtonV2\n                variant=\"ghost\"\n                shape=\"pill\"\n                css={[showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle]}\n                data-highlighted={shouldHighlightShowAllButton}\n                onClick={() => toggleShowAll(!showAll)}\n                tabIndex={-1}\n              >\n                {showAll ? messages.showLessResultLabel : messages.allResultLabel}\n                {showAll ? <ChevronUp /> : <ChevronDown />}\n              </ButtonV2>\n            </StyledListItem>\n          )}\n        </StyledList>\n      ) : (\n        <StyledNoHit inMenu={inMenu}>{messages.noHit}</StyledNoHit>\n      )}\n    </StyledWrapper>\n  );\n};\n\nexport default ContentTypeResult;\n"]} */")],
135
+ css: [showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle, ";label:ContentTypeResult;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeResult.tsx"],"names":[],"mappings":"AAqKgB","file":"ContentTypeResult.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { ReactElement, useEffect, useRef, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { Additional, ChevronDown, ChevronUp } from \"@ndla/icons/common\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Tooltip } from \"@ndla/tooltip\";\nimport {\n  highlightStyle,\n  noWidthhighlightStyle,\n  showAllButtonStyle,\n  StyledHeader,\n  StyledList,\n  StyledListItem,\n  StyledNoHit,\n  StyledTag,\n  StyledWrapper,\n} from \"./ContentTypeResultStyles\";\nimport { isPathToHighlight } from \"./IsPathToHighlight\";\nimport ContentTypeBadge from \"../ContentTypeBadge\";\nimport { ContentTypeResultType, Resource } from \"../types\";\n\nconst renderAdditionalIcon = (label: string, isAdditional?: boolean): ReactElement | null => {\n  if (isAdditional && label) {\n    return (\n      <Tooltip tooltip={label}>\n        <div>\n          <Additional size=\"medium\" aria-hidden={false} />\n        </div>\n      </Tooltip>\n    );\n  }\n  if (isAdditional) {\n    return <Additional size=\"medium\" />;\n  }\n  return null;\n};\n\ntype Props = {\n  contentTypeResult: ContentTypeResultType;\n  onNavigate?: VoidFunction;\n  defaultCount?: number;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  showAdditionalResources?: boolean;\n  messages: {\n    allResultLabel?: string;\n    showLessResultLabel?: string;\n    noHit: string;\n  };\n  ignoreContentTypeBadge?: boolean;\n  keyboardPathNavigation?: HTMLElement | string | null;\n  inMenu?: boolean;\n  animateList?: number;\n  unGrouped?: boolean;\n};\n\nconst ContentTypeResult = ({\n  contentTypeResult,\n  onNavigate,\n  defaultCount,\n  resourceToLinkProps,\n  showAdditionalResources,\n  messages,\n  ignoreContentTypeBadge,\n  keyboardPathNavigation,\n  inMenu,\n  animateList,\n  unGrouped,\n}: Props) => {\n  const { t } = useTranslation();\n  const [showAll, toggleShowAll] = useState(false);\n  const showAllRef = useRef<HTMLLIElement>(null);\n\n  const results =\n    showAdditionalResources || !contentTypeResult.resources\n      ? contentTypeResult.resources\n      : contentTypeResult.resources.filter((items) => !items.additional);\n\n  const resources = showAll || !defaultCount ? results : results.slice(0, defaultCount);\n\n  const displayShowAllButton = defaultCount && results.length > defaultCount;\n  const shouldHighlightShowAllButton = showAllRef.current === keyboardPathNavigation;\n\n  useEffect(() => {\n    if (showAll && showAllRef.current) {\n      showAllRef.current.scrollIntoView({\n        behavior: \"smooth\",\n        block: \"nearest\",\n      });\n    }\n  }, [showAll]);\n\n  return (\n    <StyledWrapper>\n      {!unGrouped && (\n        <StyledHeader>\n          {!ignoreContentTypeBadge && contentTypeResult.contentType && (\n            <ContentTypeBadge type={contentTypeResult.contentType} size=\"x-small\" background border />\n          )}\n          <h1>\n            {contentTypeResult.title} <small>({results.length})</small>\n          </h1>\n        </StyledHeader>\n      )}\n      {resources.length > 0 ? (\n        <StyledList inMenu={inMenu} animateList={animateList} unGrouped={unGrouped}>\n          {resources.map((resource) => {\n            const { path, name, resourceTypes, subject, additional } = resource;\n\n            const linkProps = resourceToLinkProps(resource);\n            const linkContent = (\n              <>\n                <strong>{name}</strong>\n                {!inMenu && subject && <small>{subject}</small>}\n                {!inMenu &&\n                  resourceTypes &&\n                  resourceTypes.map((type) => <StyledTag key={type.name}>{type.name}</StyledTag>)}\n              </>\n            );\n            const delayAnimation = !!animateList && !!additional && animateList > 0 && !!showAdditionalResources;\n\n            // Figure out highlighting by comparing path of link with keyboard navigated anchor\n            const anchor =\n              keyboardPathNavigation instanceof HTMLElement && keyboardPathNavigation\n                ? keyboardPathNavigation.querySelector(\"a\")\n                : undefined;\n            const anchorHref = anchor?.getAttribute(\"href\") ?? null;\n            const shouldHighlight = isPathToHighlight(path, anchorHref);\n\n            return (\n              <StyledListItem key={path} delayAnimation={delayAnimation}>\n                <SafeLink\n                  css={shouldHighlight && highlightStyle}\n                  data-highlighted={shouldHighlight || false}\n                  {...linkProps}\n                  onClick={() => {\n                    if (onNavigate) {\n                      onNavigate();\n                    }\n                  }}\n                >\n                  {unGrouped && !ignoreContentTypeBadge && (\n                    <ContentTypeBadge type={resource.contentType ?? \"\"} size=\"x-small\" background border />\n                  )}\n                  {linkContent}\n                  {renderAdditionalIcon(t(\"resource.additionalTooltip\"), additional)}\n                </SafeLink>\n              </StyledListItem>\n            );\n          })}\n          {displayShowAllButton && (\n            <StyledListItem ref={showAllRef}>\n              <ButtonV2\n                variant=\"ghost\"\n                shape=\"pill\"\n                css={[showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle]}\n                data-highlighted={shouldHighlightShowAllButton}\n                onClick={() => toggleShowAll(!showAll)}\n                tabIndex={-1}\n              >\n                {showAll ? messages.showLessResultLabel : messages.allResultLabel}\n                {showAll ? <ChevronUp /> : <ChevronDown />}\n              </ButtonV2>\n            </StyledListItem>\n          )}\n        </StyledList>\n      ) : (\n        <StyledNoHit inMenu={inMenu}>{messages.noHit}</StyledNoHit>\n      )}\n    </StyledWrapper>\n  );\n};\n\nexport default ContentTypeResult;\n"]} */")],
136
136
  "data-highlighted": shouldHighlightShowAllButton,
137
137
  onClick: () => toggleShowAll(!showAll),
138
138
  tabIndex: -1,