@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.
- package/es/ContactBlock/ContactBlock.js +31 -24
- package/es/Embed/ImageEmbed.js +3 -3
- package/es/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/es/Figure/index.js +1 -2
- package/es/Notion/NotionImage.js +15 -10
- package/es/Search/ContentTypeResult.js +3 -3
- package/es/Search/SearchResultSleeve.js +11 -11
- package/es/Table/Table.js +16 -13
- package/lib/ContactBlock/ContactBlock.js +31 -24
- package/lib/Embed/ImageEmbed.js +3 -3
- package/lib/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/lib/Figure/index.d.ts +0 -1
- package/lib/Figure/index.js +0 -7
- package/lib/Notion/NotionImage.d.ts +5 -0
- package/lib/Notion/NotionImage.js +14 -9
- package/lib/Search/ContentTypeResult.js +3 -3
- package/lib/Search/SearchResultSleeve.js +11 -11
- package/lib/Table/Table.js +16 -13
- package/package.json +9 -9
- package/src/ContactBlock/ContactBlock.tsx +10 -2
- package/src/Embed/ImageEmbed.tsx +4 -4
- package/src/ErrorMessage/ErrorResourceAccessDenied.tsx +2 -2
- package/src/Figure/index.ts +0 -1
- package/src/Notion/NotionImage.tsx +33 -8
- package/src/Search/ContentTypeResult.tsx +2 -2
- package/src/Search/SearchResultSleeve.tsx +3 -3
- package/src/Table/Table.tsx +6 -2
- package/es/Figure/figureActionIndicatorStyle.js +0 -13
- package/lib/Figure/figureActionIndicatorStyle.d.ts +0 -8
- package/lib/Figure/figureActionIndicatorStyle.js +0 -19
- package/src/Figure/figureActionIndicatorStyle.ts +0 -39
package/es/Embed/ImageEmbed.js
CHANGED
|
@@ -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,
|
|
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: "
|
|
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: "
|
|
42
|
+
size: "medium"
|
|
43
43
|
})
|
|
44
44
|
})]
|
|
45
45
|
})
|
package/es/Figure/index.js
CHANGED
package/es/Notion/NotionImage.js
CHANGED
|
@@ -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
|
|
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: "
|
|
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,
|
|
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: "
|
|
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,
|
|
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: "
|
|
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,
|
|
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(
|
|
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: "
|
|
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: "
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbnRlbnRUeXBlUmVzdWx0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxS2dCIiwiZmlsZSI6IkNvbnRlbnRUeXBlUmVzdWx0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuLyoqIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7IFJlYWN0RWxlbWVudCwgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gXCJyZWFjdC1pMThuZXh0XCI7XG5pbXBvcnQgeyBCdXR0b25WMiB9IGZyb20gXCJAbmRsYS9idXR0b25cIjtcbmltcG9ydCB7IEFkZGl0aW9uYWwsIENoZXZyb25Eb3duLCBDaGV2cm9uVXAgfSBmcm9tIFwiQG5kbGEvaWNvbnMvY29tbW9uXCI7XG5pbXBvcnQgeyBTYWZlTGluayB9IGZyb20gXCJAbmRsYS9zYWZlbGlua1wiO1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gXCJAbmRsYS90b29sdGlwXCI7XG5pbXBvcnQge1xuICBoaWdobGlnaHRTdHlsZSxcbiAgbm9XaWR0aGhpZ2hsaWdodFN0eWxlLFxuICBzaG93QWxsQnV0dG9uU3R5bGUsXG4gIFN0eWxlZEhlYWRlcixcbiAgU3R5bGVkTGlzdCxcbiAgU3R5bGVkTGlzdEl0ZW0sXG4gIFN0eWxlZE5vSGl0LFxuICBTdHlsZWRUYWcsXG4gIFN0eWxlZFdyYXBwZXIsXG59IGZyb20gXCIuL0NvbnRlbnRUeXBlUmVzdWx0U3R5bGVzXCI7XG5pbXBvcnQgeyBpc1BhdGhUb0hpZ2hsaWdodCB9IGZyb20gXCIuL0lzUGF0aFRvSGlnaGxpZ2h0XCI7XG5pbXBvcnQgQ29udGVudFR5cGVCYWRnZSBmcm9tIFwiLi4vQ29udGVudFR5cGVCYWRnZVwiO1xuaW1wb3J0IHsgQ29udGVudFR5cGVSZXN1bHRUeXBlLCBSZXNvdXJjZSB9IGZyb20gXCIuLi90eXBlc1wiO1xuXG5jb25zdCByZW5kZXJBZGRpdGlvbmFsSWNvbiA9IChsYWJlbDogc3RyaW5nLCBpc0FkZGl0aW9uYWw/
|
|
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,
|