@ndla/ui 34.7.0 → 35.0.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.
@@ -35,7 +35,7 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
35
35
  var LinkedVideoButton = /*#__PURE__*/_styled(ButtonV2, {
36
36
  target: "e2wbdyh1",
37
37
  label: "LinkedVideoButton"
38
- })("margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BrightcoveEmbed.tsx"],"names":[],"mappings":"AA4B0C","file":"BrightcoveEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport sortBy from 'lodash/sortBy';\nimport isNumber from 'lodash/isNumber';\nimport styled from '@emotion/styled';\nimport { spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { useEffect, useRef, useState } from 'react';\nimport { ModalV2 } from '@ndla/modal';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { BrightcoveEmbedData, BrightcoveMetaData, BrightcoveVideoSource } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { ButtonV2, CopyButton } from '@ndla/button';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { getFirstNonEmptyLicenseCredits } from './AudioEmbed';\n\ninterface Props {\n  embed: BrightcoveMetaData;\n  isConcept?: boolean;\n}\n\nconst LinkedVideoButton = styled(ButtonV2)`\n  margin-left: ${spacing.small};\n`;\n\nconst BrightcoveIframe = styled.iframe`\n  height: auto;\n`;\n\nexport const makeIframeString = (url: string, width: string | number, height: string | number, title: string = '') => {\n  const strippedWidth = isNumber(width) ? width : width.replace(/\\s*px/, '');\n  const strippedHeight = isNumber(height) ? height : height.replace(/\\s*px/, '');\n  const urlOrTitle = title || url;\n  return `<iframe title=\"${urlOrTitle}\" aria-label=\"${urlOrTitle}\" src=\"${url}\" width=\"${strippedWidth}\" height=\"${strippedHeight}\" allowfullscreen scrolling=\"no\" frameborder=\"0\" loading=\"lazy\"></iframe>`;\n};\n\nexport const isNumeric = (value: any) => !Number.isNaN(value - parseFloat(value));\n\nconst getIframeProps = (data: BrightcoveEmbedData, sources: BrightcoveVideoSource[]) => {\n  const { account, videoid, player = 'default' } = data;\n\n  const source = sortBy(\n    sources.filter((s) => s.width && s.height),\n    (s) => s.height,\n  )[0];\n\n  return {\n    src: `https://players.brightcove.net/${account}/${player}_default/index.html?videoId=${videoid}`,\n    height: source?.height ?? '480',\n    width: source?.width ?? '640',\n  };\n};\nconst BrightcoveEmbed = ({ embed, isConcept }: Props) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [showOriginalVideo, setShowOriginalVideo] = useState(true);\n  const { t, i18n } = useTranslation();\n  const iframeRef = useRef<HTMLIFrameElement>(null);\n  const { embedData } = embed;\n\n  useEffect(() => {\n    const iframe = iframeRef.current;\n    if (iframe) {\n      const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n      iframe.style.aspectRatio = `${width}/${height}`;\n    }\n  }, []);\n  if (embed.status === 'error') {\n    return (\n      <Figure type={isConcept ? 'full-column' : 'full'} resizeIframe>\n        <BrightcoveIframe\n          ref={iframeRef}\n          title={`Video: ${embedData.videoid ?? ''}`}\n          aria-label={`Video: ${embedData.videoid ?? ''}`}\n          frameBorder=\"0\"\n          {...getIframeProps(embedData, [])}\n          allowFullScreen\n        />\n        <figcaption>{t('video.error')}</figcaption>\n      </Figure>\n    );\n  }\n  const { data, seq } = embed;\n\n  const linkedVideoId = isNumeric(data.link?.text) ? data.link?.text : undefined;\n\n  const license = getLicenseByAbbreviation(data.copyright?.license.license ?? '', i18n.language);\n  const contributors = data.copyright\n    ? getGroupedContributorDescriptionList(data.copyright, i18n.language).map((item) => ({\n        name: item.description,\n        type: item.label,\n      }))\n    : [];\n\n  const { rightsholders = [], creators = [], processors = [] } = data.copyright ?? {};\n\n  const download = sortBy(\n    data.sources.filter((src) => src.container === 'MP4' && src.src),\n    (src) => src.size,\n  )?.[0]?.src;\n\n  const figureId = `figure-${seq}-${data.id}`;\n  const originalVideoProps = getIframeProps(embedData, data.sources);\n  const alternativeVideoProps = linkedVideoId\n    ? getIframeProps({ ...embedData, videoid: linkedVideoId }, data.sources)\n    : undefined;\n  const captionAuthors = getFirstNonEmptyLicenseCredits({ rightsholders, creators, processors });\n\n  return (\n    <Figure id={figureId} type={isConcept ? 'full-column' : 'full'} resizeIframe>\n      <div className=\"brightcove-video\">\n        <BrightcoveIframe\n          ref={iframeRef}\n          className=\"original\"\n          title={`Video: ${data.name}`}\n          aria-label={`Video: ${data.name}`}\n          frameBorder=\"0\"\n          {...(alternativeVideoProps && !showOriginalVideo ? alternativeVideoProps : originalVideoProps)}\n          allowFullScreen\n        />\n      </div>\n      <FigureCaption\n        figureId={figureId}\n        id={data.id}\n        locale={i18n.language}\n        caption={embedData.caption ?? ''}\n        modalButton={\n          <ButtonV2 variant=\"outline\" shape=\"pill\" size=\"small\" onClick={() => setIsOpen(true)}>\n            {t('video.reuse')}\n          </ButtonV2>\n        }\n        linkedVideoButton={\n          <LinkedVideoButton\n            variant=\"outline\"\n            shape=\"pill\"\n            size=\"small\"\n            onClick={() => setShowOriginalVideo((p) => !p)}>\n            {t(`figure.button.${showOriginalVideo ? 'original' : 'alternative'}`)}\n          </LinkedVideoButton>\n        }\n        licenseRights={license.rights}\n        authors={captionAuthors}\n        hasLinkedVideo={!!linkedVideoId}\n      />\n      <ModalV2 controlled isOpen={isOpen} onClose={() => setIsOpen(false)} labelledBy=\"license-dialog-rules-heading\">\n        {(close) => (\n          <FigureLicenseDialogContent\n            onClose={close}\n            title={data.name}\n            locale={i18n.language}\n            license={license}\n            authors={contributors}\n            type=\"video\">\n            <VideoLicenseButtons\n              download={download}\n              licenseCode={data.copyright?.license.license}\n              src={originalVideoProps.src}\n              width={originalVideoProps.width}\n              height={originalVideoProps.height}\n              name={data.name}\n            />\n          </FigureLicenseDialogContent>\n        )}\n      </ModalV2>\n    </Figure>\n  );\n};\n\ninterface VideoLicenseButtonsProps {\n  download: string;\n  licenseCode?: string;\n  src: string;\n  width: string | number;\n  height: string | number;\n  name?: string;\n}\n\nconst VideoLicenseButtons = ({ download, src, width, height, name, licenseCode }: VideoLicenseButtonsProps) => {\n  const { t } = useTranslation();\n  return (\n    <>\n      {licenseCode !== 'COPYRIGHTED' && (\n        <SafeLinkButton key=\"download\" to={download} variant=\"outline\" download>\n          {t('video.download')}\n        </SafeLinkButton>\n      )}\n      <CopyButton\n        variant=\"outline\"\n        copyNode={t('license.hasCopiedTitle')}\n        onClick={() => navigator.clipboard.writeText(makeIframeString(src, width, height, name))}>\n        {t('license.embed')}\n      </CopyButton>\n    </>\n  );\n};\n\nexport default BrightcoveEmbed;\n"]} */"));
38
+ })("margin-left:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BrightcoveEmbed.tsx"],"names":[],"mappings":"AA4B0C","file":"BrightcoveEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport sortBy from 'lodash/sortBy';\nimport isNumber from 'lodash/isNumber';\nimport styled from '@emotion/styled';\nimport { spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { useEffect, useRef, useState } from 'react';\nimport { ModalV2 } from '@ndla/modal';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { BrightcoveEmbedData, BrightcoveMetaData, BrightcoveVideoSource } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { ButtonV2, CopyButton } from '@ndla/button';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { getFirstNonEmptyLicenseCredits } from './AudioEmbed';\n\ninterface Props {\n  embed: BrightcoveMetaData;\n  isConcept?: boolean;\n}\n\nconst LinkedVideoButton = styled(ButtonV2)`\n  margin-left: ${spacing.small};\n`;\n\nconst BrightcoveIframe = styled.iframe`\n  height: auto;\n`;\n\nexport const makeIframeString = (url: string, width: string | number, height: string | number, title: string = '') => {\n  const strippedWidth = isNumber(width) ? width : width.replace(/\\s*px/, '');\n  const strippedHeight = isNumber(height) ? height : height.replace(/\\s*px/, '');\n  const urlOrTitle = title || url;\n  return `<iframe title=\"${urlOrTitle}\" aria-label=\"${urlOrTitle}\" src=\"${url}\" width=\"${strippedWidth}\" height=\"${strippedHeight}\" allowfullscreen scrolling=\"no\" frameborder=\"0\" loading=\"lazy\"></iframe>`;\n};\n\nexport const isNumeric = (value: any) => !Number.isNaN(value - parseFloat(value));\n\nconst getIframeProps = (data: BrightcoveEmbedData, sources: BrightcoveVideoSource[]) => {\n  const { account, videoid, player = 'default' } = data;\n\n  const source = sortBy(\n    sources.filter((s) => s.width && s.height),\n    (s) => s.height,\n  )[0];\n\n  return {\n    src: `https://players.brightcove.net/${account}/${player}_default/index.html?videoId=${videoid}`,\n    height: source?.height ?? '480',\n    width: source?.width ?? '640',\n  };\n};\nconst BrightcoveEmbed = ({ embed, isConcept }: Props) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [showOriginalVideo, setShowOriginalVideo] = useState(true);\n  const { t, i18n } = useTranslation();\n  const iframeRef = useRef<HTMLIFrameElement>(null);\n  const { embedData } = embed;\n\n  useEffect(() => {\n    const iframe = iframeRef.current;\n    if (iframe) {\n      const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n      iframe.style.aspectRatio = `${width}/${height}`;\n      iframe.width = '';\n      iframe.height = '';\n    }\n  }, []);\n  if (embed.status === 'error') {\n    return (\n      <Figure type={isConcept ? 'full-column' : 'full'} resizeIframe>\n        <BrightcoveIframe\n          ref={iframeRef}\n          title={`Video: ${embedData.videoid ?? ''}`}\n          aria-label={`Video: ${embedData.videoid ?? ''}`}\n          frameBorder=\"0\"\n          {...getIframeProps(embedData, [])}\n          allowFullScreen\n        />\n        <figcaption>{t('video.error')}</figcaption>\n      </Figure>\n    );\n  }\n  const { data, seq } = embed;\n\n  const linkedVideoId = isNumeric(data.link?.text) ? data.link?.text : undefined;\n\n  const license = getLicenseByAbbreviation(data.copyright?.license.license ?? '', i18n.language);\n  const contributors = data.copyright\n    ? getGroupedContributorDescriptionList(data.copyright, i18n.language).map((item) => ({\n        name: item.description,\n        type: item.label,\n      }))\n    : [];\n\n  const { rightsholders = [], creators = [], processors = [] } = data.copyright ?? {};\n\n  const download = sortBy(\n    data.sources.filter((src) => src.container === 'MP4' && src.src),\n    (src) => src.size,\n  )?.[0]?.src;\n\n  const figureId = `figure-${seq}-${data.id}`;\n  const originalVideoProps = getIframeProps(embedData, data.sources);\n  const alternativeVideoProps = linkedVideoId\n    ? getIframeProps({ ...embedData, videoid: linkedVideoId }, data.sources)\n    : undefined;\n  const captionAuthors = getFirstNonEmptyLicenseCredits({ rightsholders, creators, processors });\n\n  return (\n    <Figure id={figureId} type={isConcept ? 'full-column' : 'full'} resizeIframe>\n      <div className=\"brightcove-video\">\n        <BrightcoveIframe\n          ref={iframeRef}\n          className=\"original\"\n          title={`Video: ${data.name}`}\n          aria-label={`Video: ${data.name}`}\n          frameBorder=\"0\"\n          {...(alternativeVideoProps && !showOriginalVideo ? alternativeVideoProps : originalVideoProps)}\n          allowFullScreen\n        />\n      </div>\n      <FigureCaption\n        figureId={figureId}\n        id={data.id}\n        locale={i18n.language}\n        caption={embedData.caption ?? ''}\n        modalButton={\n          <ButtonV2 variant=\"outline\" shape=\"pill\" size=\"small\" onClick={() => setIsOpen(true)}>\n            {t('video.reuse')}\n          </ButtonV2>\n        }\n        linkedVideoButton={\n          <LinkedVideoButton\n            variant=\"outline\"\n            shape=\"pill\"\n            size=\"small\"\n            onClick={() => setShowOriginalVideo((p) => !p)}>\n            {t(`figure.button.${showOriginalVideo ? 'original' : 'alternative'}`)}\n          </LinkedVideoButton>\n        }\n        licenseRights={license.rights}\n        authors={captionAuthors}\n        hasLinkedVideo={!!linkedVideoId}\n      />\n      <ModalV2 controlled isOpen={isOpen} onClose={() => setIsOpen(false)} labelledBy=\"license-dialog-rules-heading\">\n        {(close) => (\n          <FigureLicenseDialogContent\n            onClose={close}\n            title={data.name}\n            locale={i18n.language}\n            license={license}\n            authors={contributors}\n            type=\"video\">\n            <VideoLicenseButtons\n              download={download}\n              licenseCode={data.copyright?.license.license}\n              src={originalVideoProps.src}\n              width={originalVideoProps.width}\n              height={originalVideoProps.height}\n              name={data.name}\n            />\n          </FigureLicenseDialogContent>\n        )}\n      </ModalV2>\n    </Figure>\n  );\n};\n\ninterface VideoLicenseButtonsProps {\n  download: string;\n  licenseCode?: string;\n  src: string;\n  width: string | number;\n  height: string | number;\n  name?: string;\n}\n\nconst VideoLicenseButtons = ({ download, src, width, height, name, licenseCode }: VideoLicenseButtonsProps) => {\n  const { t } = useTranslation();\n  return (\n    <>\n      {licenseCode !== 'COPYRIGHTED' && (\n        <SafeLinkButton key=\"download\" to={download} variant=\"outline\" download>\n          {t('video.download')}\n        </SafeLinkButton>\n      )}\n      <CopyButton\n        variant=\"outline\"\n        copyNode={t('license.hasCopiedTitle')}\n        onClick={() => navigator.clipboard.writeText(makeIframeString(src, width, height, name))}>\n        {t('license.embed')}\n      </CopyButton>\n    </>\n  );\n};\n\nexport default BrightcoveEmbed;\n"]} */"));
39
39
  var BrightcoveIframe = /*#__PURE__*/_styled("iframe", {
40
40
  target: "e2wbdyh0",
41
41
  label: "BrightcoveIframe"
@@ -45,7 +45,7 @@ var BrightcoveIframe = /*#__PURE__*/_styled("iframe", {
45
45
  } : {
46
46
  name: "pit38s",
47
47
  styles: "height:auto",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BrightcoveEmbed.tsx"],"names":[],"mappings":"AAgCsC","file":"BrightcoveEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport sortBy from 'lodash/sortBy';\nimport isNumber from 'lodash/isNumber';\nimport styled from '@emotion/styled';\nimport { spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { useEffect, useRef, useState } from 'react';\nimport { ModalV2 } from '@ndla/modal';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { BrightcoveEmbedData, BrightcoveMetaData, BrightcoveVideoSource } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { ButtonV2, CopyButton } from '@ndla/button';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { getFirstNonEmptyLicenseCredits } from './AudioEmbed';\n\ninterface Props {\n  embed: BrightcoveMetaData;\n  isConcept?: boolean;\n}\n\nconst LinkedVideoButton = styled(ButtonV2)`\n  margin-left: ${spacing.small};\n`;\n\nconst BrightcoveIframe = styled.iframe`\n  height: auto;\n`;\n\nexport const makeIframeString = (url: string, width: string | number, height: string | number, title: string = '') => {\n  const strippedWidth = isNumber(width) ? width : width.replace(/\\s*px/, '');\n  const strippedHeight = isNumber(height) ? height : height.replace(/\\s*px/, '');\n  const urlOrTitle = title || url;\n  return `<iframe title=\"${urlOrTitle}\" aria-label=\"${urlOrTitle}\" src=\"${url}\" width=\"${strippedWidth}\" height=\"${strippedHeight}\" allowfullscreen scrolling=\"no\" frameborder=\"0\" loading=\"lazy\"></iframe>`;\n};\n\nexport const isNumeric = (value: any) => !Number.isNaN(value - parseFloat(value));\n\nconst getIframeProps = (data: BrightcoveEmbedData, sources: BrightcoveVideoSource[]) => {\n  const { account, videoid, player = 'default' } = data;\n\n  const source = sortBy(\n    sources.filter((s) => s.width && s.height),\n    (s) => s.height,\n  )[0];\n\n  return {\n    src: `https://players.brightcove.net/${account}/${player}_default/index.html?videoId=${videoid}`,\n    height: source?.height ?? '480',\n    width: source?.width ?? '640',\n  };\n};\nconst BrightcoveEmbed = ({ embed, isConcept }: Props) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [showOriginalVideo, setShowOriginalVideo] = useState(true);\n  const { t, i18n } = useTranslation();\n  const iframeRef = useRef<HTMLIFrameElement>(null);\n  const { embedData } = embed;\n\n  useEffect(() => {\n    const iframe = iframeRef.current;\n    if (iframe) {\n      const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n      iframe.style.aspectRatio = `${width}/${height}`;\n    }\n  }, []);\n  if (embed.status === 'error') {\n    return (\n      <Figure type={isConcept ? 'full-column' : 'full'} resizeIframe>\n        <BrightcoveIframe\n          ref={iframeRef}\n          title={`Video: ${embedData.videoid ?? ''}`}\n          aria-label={`Video: ${embedData.videoid ?? ''}`}\n          frameBorder=\"0\"\n          {...getIframeProps(embedData, [])}\n          allowFullScreen\n        />\n        <figcaption>{t('video.error')}</figcaption>\n      </Figure>\n    );\n  }\n  const { data, seq } = embed;\n\n  const linkedVideoId = isNumeric(data.link?.text) ? data.link?.text : undefined;\n\n  const license = getLicenseByAbbreviation(data.copyright?.license.license ?? '', i18n.language);\n  const contributors = data.copyright\n    ? getGroupedContributorDescriptionList(data.copyright, i18n.language).map((item) => ({\n        name: item.description,\n        type: item.label,\n      }))\n    : [];\n\n  const { rightsholders = [], creators = [], processors = [] } = data.copyright ?? {};\n\n  const download = sortBy(\n    data.sources.filter((src) => src.container === 'MP4' && src.src),\n    (src) => src.size,\n  )?.[0]?.src;\n\n  const figureId = `figure-${seq}-${data.id}`;\n  const originalVideoProps = getIframeProps(embedData, data.sources);\n  const alternativeVideoProps = linkedVideoId\n    ? getIframeProps({ ...embedData, videoid: linkedVideoId }, data.sources)\n    : undefined;\n  const captionAuthors = getFirstNonEmptyLicenseCredits({ rightsholders, creators, processors });\n\n  return (\n    <Figure id={figureId} type={isConcept ? 'full-column' : 'full'} resizeIframe>\n      <div className=\"brightcove-video\">\n        <BrightcoveIframe\n          ref={iframeRef}\n          className=\"original\"\n          title={`Video: ${data.name}`}\n          aria-label={`Video: ${data.name}`}\n          frameBorder=\"0\"\n          {...(alternativeVideoProps && !showOriginalVideo ? alternativeVideoProps : originalVideoProps)}\n          allowFullScreen\n        />\n      </div>\n      <FigureCaption\n        figureId={figureId}\n        id={data.id}\n        locale={i18n.language}\n        caption={embedData.caption ?? ''}\n        modalButton={\n          <ButtonV2 variant=\"outline\" shape=\"pill\" size=\"small\" onClick={() => setIsOpen(true)}>\n            {t('video.reuse')}\n          </ButtonV2>\n        }\n        linkedVideoButton={\n          <LinkedVideoButton\n            variant=\"outline\"\n            shape=\"pill\"\n            size=\"small\"\n            onClick={() => setShowOriginalVideo((p) => !p)}>\n            {t(`figure.button.${showOriginalVideo ? 'original' : 'alternative'}`)}\n          </LinkedVideoButton>\n        }\n        licenseRights={license.rights}\n        authors={captionAuthors}\n        hasLinkedVideo={!!linkedVideoId}\n      />\n      <ModalV2 controlled isOpen={isOpen} onClose={() => setIsOpen(false)} labelledBy=\"license-dialog-rules-heading\">\n        {(close) => (\n          <FigureLicenseDialogContent\n            onClose={close}\n            title={data.name}\n            locale={i18n.language}\n            license={license}\n            authors={contributors}\n            type=\"video\">\n            <VideoLicenseButtons\n              download={download}\n              licenseCode={data.copyright?.license.license}\n              src={originalVideoProps.src}\n              width={originalVideoProps.width}\n              height={originalVideoProps.height}\n              name={data.name}\n            />\n          </FigureLicenseDialogContent>\n        )}\n      </ModalV2>\n    </Figure>\n  );\n};\n\ninterface VideoLicenseButtonsProps {\n  download: string;\n  licenseCode?: string;\n  src: string;\n  width: string | number;\n  height: string | number;\n  name?: string;\n}\n\nconst VideoLicenseButtons = ({ download, src, width, height, name, licenseCode }: VideoLicenseButtonsProps) => {\n  const { t } = useTranslation();\n  return (\n    <>\n      {licenseCode !== 'COPYRIGHTED' && (\n        <SafeLinkButton key=\"download\" to={download} variant=\"outline\" download>\n          {t('video.download')}\n        </SafeLinkButton>\n      )}\n      <CopyButton\n        variant=\"outline\"\n        copyNode={t('license.hasCopiedTitle')}\n        onClick={() => navigator.clipboard.writeText(makeIframeString(src, width, height, name))}>\n        {t('license.embed')}\n      </CopyButton>\n    </>\n  );\n};\n\nexport default BrightcoveEmbed;\n"]} */",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BrightcoveEmbed.tsx"],"names":[],"mappings":"AAgCsC","file":"BrightcoveEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport sortBy from 'lodash/sortBy';\nimport isNumber from 'lodash/isNumber';\nimport styled from '@emotion/styled';\nimport { spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { useEffect, useRef, useState } from 'react';\nimport { ModalV2 } from '@ndla/modal';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { BrightcoveEmbedData, BrightcoveMetaData, BrightcoveVideoSource } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { ButtonV2, CopyButton } from '@ndla/button';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { getFirstNonEmptyLicenseCredits } from './AudioEmbed';\n\ninterface Props {\n  embed: BrightcoveMetaData;\n  isConcept?: boolean;\n}\n\nconst LinkedVideoButton = styled(ButtonV2)`\n  margin-left: ${spacing.small};\n`;\n\nconst BrightcoveIframe = styled.iframe`\n  height: auto;\n`;\n\nexport const makeIframeString = (url: string, width: string | number, height: string | number, title: string = '') => {\n  const strippedWidth = isNumber(width) ? width : width.replace(/\\s*px/, '');\n  const strippedHeight = isNumber(height) ? height : height.replace(/\\s*px/, '');\n  const urlOrTitle = title || url;\n  return `<iframe title=\"${urlOrTitle}\" aria-label=\"${urlOrTitle}\" src=\"${url}\" width=\"${strippedWidth}\" height=\"${strippedHeight}\" allowfullscreen scrolling=\"no\" frameborder=\"0\" loading=\"lazy\"></iframe>`;\n};\n\nexport const isNumeric = (value: any) => !Number.isNaN(value - parseFloat(value));\n\nconst getIframeProps = (data: BrightcoveEmbedData, sources: BrightcoveVideoSource[]) => {\n  const { account, videoid, player = 'default' } = data;\n\n  const source = sortBy(\n    sources.filter((s) => s.width && s.height),\n    (s) => s.height,\n  )[0];\n\n  return {\n    src: `https://players.brightcove.net/${account}/${player}_default/index.html?videoId=${videoid}`,\n    height: source?.height ?? '480',\n    width: source?.width ?? '640',\n  };\n};\nconst BrightcoveEmbed = ({ embed, isConcept }: Props) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [showOriginalVideo, setShowOriginalVideo] = useState(true);\n  const { t, i18n } = useTranslation();\n  const iframeRef = useRef<HTMLIFrameElement>(null);\n  const { embedData } = embed;\n\n  useEffect(() => {\n    const iframe = iframeRef.current;\n    if (iframe) {\n      const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n      iframe.style.aspectRatio = `${width}/${height}`;\n      iframe.width = '';\n      iframe.height = '';\n    }\n  }, []);\n  if (embed.status === 'error') {\n    return (\n      <Figure type={isConcept ? 'full-column' : 'full'} resizeIframe>\n        <BrightcoveIframe\n          ref={iframeRef}\n          title={`Video: ${embedData.videoid ?? ''}`}\n          aria-label={`Video: ${embedData.videoid ?? ''}`}\n          frameBorder=\"0\"\n          {...getIframeProps(embedData, [])}\n          allowFullScreen\n        />\n        <figcaption>{t('video.error')}</figcaption>\n      </Figure>\n    );\n  }\n  const { data, seq } = embed;\n\n  const linkedVideoId = isNumeric(data.link?.text) ? data.link?.text : undefined;\n\n  const license = getLicenseByAbbreviation(data.copyright?.license.license ?? '', i18n.language);\n  const contributors = data.copyright\n    ? getGroupedContributorDescriptionList(data.copyright, i18n.language).map((item) => ({\n        name: item.description,\n        type: item.label,\n      }))\n    : [];\n\n  const { rightsholders = [], creators = [], processors = [] } = data.copyright ?? {};\n\n  const download = sortBy(\n    data.sources.filter((src) => src.container === 'MP4' && src.src),\n    (src) => src.size,\n  )?.[0]?.src;\n\n  const figureId = `figure-${seq}-${data.id}`;\n  const originalVideoProps = getIframeProps(embedData, data.sources);\n  const alternativeVideoProps = linkedVideoId\n    ? getIframeProps({ ...embedData, videoid: linkedVideoId }, data.sources)\n    : undefined;\n  const captionAuthors = getFirstNonEmptyLicenseCredits({ rightsholders, creators, processors });\n\n  return (\n    <Figure id={figureId} type={isConcept ? 'full-column' : 'full'} resizeIframe>\n      <div className=\"brightcove-video\">\n        <BrightcoveIframe\n          ref={iframeRef}\n          className=\"original\"\n          title={`Video: ${data.name}`}\n          aria-label={`Video: ${data.name}`}\n          frameBorder=\"0\"\n          {...(alternativeVideoProps && !showOriginalVideo ? alternativeVideoProps : originalVideoProps)}\n          allowFullScreen\n        />\n      </div>\n      <FigureCaption\n        figureId={figureId}\n        id={data.id}\n        locale={i18n.language}\n        caption={embedData.caption ?? ''}\n        modalButton={\n          <ButtonV2 variant=\"outline\" shape=\"pill\" size=\"small\" onClick={() => setIsOpen(true)}>\n            {t('video.reuse')}\n          </ButtonV2>\n        }\n        linkedVideoButton={\n          <LinkedVideoButton\n            variant=\"outline\"\n            shape=\"pill\"\n            size=\"small\"\n            onClick={() => setShowOriginalVideo((p) => !p)}>\n            {t(`figure.button.${showOriginalVideo ? 'original' : 'alternative'}`)}\n          </LinkedVideoButton>\n        }\n        licenseRights={license.rights}\n        authors={captionAuthors}\n        hasLinkedVideo={!!linkedVideoId}\n      />\n      <ModalV2 controlled isOpen={isOpen} onClose={() => setIsOpen(false)} labelledBy=\"license-dialog-rules-heading\">\n        {(close) => (\n          <FigureLicenseDialogContent\n            onClose={close}\n            title={data.name}\n            locale={i18n.language}\n            license={license}\n            authors={contributors}\n            type=\"video\">\n            <VideoLicenseButtons\n              download={download}\n              licenseCode={data.copyright?.license.license}\n              src={originalVideoProps.src}\n              width={originalVideoProps.width}\n              height={originalVideoProps.height}\n              name={data.name}\n            />\n          </FigureLicenseDialogContent>\n        )}\n      </ModalV2>\n    </Figure>\n  );\n};\n\ninterface VideoLicenseButtonsProps {\n  download: string;\n  licenseCode?: string;\n  src: string;\n  width: string | number;\n  height: string | number;\n  name?: string;\n}\n\nconst VideoLicenseButtons = ({ download, src, width, height, name, licenseCode }: VideoLicenseButtonsProps) => {\n  const { t } = useTranslation();\n  return (\n    <>\n      {licenseCode !== 'COPYRIGHTED' && (\n        <SafeLinkButton key=\"download\" to={download} variant=\"outline\" download>\n          {t('video.download')}\n        </SafeLinkButton>\n      )}\n      <CopyButton\n        variant=\"outline\"\n        copyNode={t('license.hasCopiedTitle')}\n        onClick={() => navigator.clipboard.writeText(makeIframeString(src, width, height, name))}>\n        {t('license.embed')}\n      </CopyButton>\n    </>\n  );\n};\n\nexport default BrightcoveEmbed;\n"]} */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  });
51
51
  export var makeIframeString = function makeIframeString(url, width, height) {
@@ -99,6 +99,8 @@ var BrightcoveEmbed = function BrightcoveEmbed(_ref) {
99
99
  width = _ref2[0],
100
100
  height = _ref2[1];
101
101
  iframe.style.aspectRatio = "".concat(width, "/").concat(height);
102
+ iframe.width = '';
103
+ iframe.height = '';
102
104
  }
103
105
  }, []);
104
106
  if (embed.status === 'error') {
@@ -24,7 +24,7 @@ var StyledFigure = /*#__PURE__*/_styled("figure", {
24
24
  } : {
25
25
  name: "9y4sui",
26
26
  styles: "iframe{height:auto;}",
27
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkV4dGVybmFsRW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCa0MiLCJmaWxlIjoiRXh0ZXJuYWxFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IE9lbWJlZE1ldGFEYXRhIH0gZnJvbSAnQG5kbGEvdHlwZXMtZW1iZWQnO1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IFJlc291cmNlQm94IH0gZnJvbSAnLi4vUmVzb3VyY2VCb3gnO1xuaW1wb3J0IHsgZXJyb3JTdmdTcmMgfSBmcm9tICcuL0ltYWdlRW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogT2VtYmVkTWV0YURhdGE7XG4gIGlzQ29uY2VwdD86IGJvb2xlYW47XG59XG5cbmNvbnN0IFN0eWxlZEZpZ3VyZSA9IHN0eWxlZC5maWd1cmVgXG4gIGlmcmFtZSB7XG4gICAgaGVpZ2h0OiBhdXRvO1xuICB9XG5gO1xuXG5jb25zdCBFeHRlcm5hbEVtYmVkID0gKHsgZW1iZWQsIGlzQ29uY2VwdCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IGZpZ1JlZiA9IHVzZVJlZjxIVE1MRWxlbWVudD4obnVsbCk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBpZnJhbWUgPSBmaWdSZWYuY3VycmVudD8ucXVlcnlTZWxlY3RvcihgaWZyYW1lYCk7XG4gICAgaWYgKGlmcmFtZSkge1xuICAgICAgY29uc3QgW3dpZHRoLCBoZWlnaHRdID0gW3BhcnNlSW50KGlmcmFtZS53aWR0aCksIHBhcnNlSW50KGlmcmFtZS5oZWlnaHQpXTtcbiAgICAgIGlmcmFtZS5zdHlsZS5hc3BlY3RSYXRpbyA9IGAke3dpZHRoID8gd2lkdGggOiAxNn0vJHtoZWlnaHQgPyBoZWlnaHQgOiA5fWA7XG4gICAgfVxuICB9LCBbXSk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPGZpZ3VyZSBjbGFzc05hbWU9e2lzQ29uY2VwdCA/ICcnIDogJ2MtZmlndXJlJ30+XG4gICAgICAgIDxpbWcgYWx0PXt0KCdleHRlcm5hbC5lcnJvcicpfSBzcmM9e2Vycm9yU3ZnU3JjfSAvPlxuICAgICAgICA8ZmlnY2FwdGlvbj57dCgnZXh0ZXJuYWwuZXJyb3InKX08L2ZpZ2NhcHRpb24+XG4gICAgICA8L2ZpZ3VyZT5cbiAgICApO1xuICB9XG5cbiAgY29uc3QgeyBlbWJlZERhdGEsIGRhdGEgfSA9IGVtYmVkO1xuXG4gIGlmIChlbWJlZERhdGEudHlwZSA9PT0gJ2Z1bGxzY3JlZW4nKSB7XG4gICAgY29uc3QgaW1hZ2UgPSB7IHNyYzogZGF0YS5pZnJhbWVJbWFnZT8uaW1hZ2VVcmwgPz8gJycsIGFsdDogZGF0YS5pZnJhbWVJbWFnZT8uYWx0dGV4dD8uYWx0dGV4dCA/PyAnJyB9O1xuICAgIHJldHVybiAoXG4gICAgICA8RmlndXJlIHR5cGU9XCJmdWxsXCI+XG4gICAgICAgIDxSZXNvdXJjZUJveFxuICAgICAgICAgIGltYWdlPXtpbWFnZX1cbiAgICAgICAgICB0aXRsZT17ZW1iZWREYXRhLnRpdGxlID8/ICcnfVxuICAgICAgICAgIHVybD17ZW1iZWREYXRhLnVybH1cbiAgICAgICAgICBjYXB0aW9uPXtlbWJlZERhdGEuY2FwdGlvbiA/PyAnJ31cbiAgICAgICAgICBidXR0b25UZXh0PXt0KCdsaWNlbnNlLm90aGVyLml0ZW1JbWFnZS5hcmlhTGFiZWwnKX1cbiAgICAgICAgLz5cbiAgICAgIDwvRmlndXJlPlxuICAgICk7XG4gIH1cblxuICBjb25zdCBmdWxsQ29sdW1uQ2xhc3MgPSBpc0NvbmNlcHQgPyAnYy1maWd1cmUtLWZ1bGwtY29sdW1uJyA6ICcnO1xuICBjb25zdCBjbGFzc2VzID0gYGMtZmlndXJlICR7ZnVsbENvbHVtbkNsYXNzfSBjLWZpZ3VyZS0tcmVzaXplYDtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRGaWd1cmVcbiAgICAgIHJlZj17ZmlnUmVmfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc2VzfVxuICAgICAgLy9AdHMtaWdub3JlXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3Qvbm8tdW5rbm93bi1wcm9wZXJ0eVxuICAgICAgcmVzaXplaWZyYW1lPVwidHJ1ZVwiXG4gICAgICBkYW5nZXJvdXNseVNldElubmVySFRNTD17eyBfX2h0bWw6IGRhdGEub2VtYmVkLmh0bWwgPz8gJycgfX1cbiAgICAvPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRXh0ZXJuYWxFbWJlZDtcbiJdfQ== */",
27
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkV4dGVybmFsRW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCa0MiLCJmaWxlIjoiRXh0ZXJuYWxFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IE9lbWJlZE1ldGFEYXRhIH0gZnJvbSAnQG5kbGEvdHlwZXMtZW1iZWQnO1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IFJlc291cmNlQm94IH0gZnJvbSAnLi4vUmVzb3VyY2VCb3gnO1xuaW1wb3J0IHsgZXJyb3JTdmdTcmMgfSBmcm9tICcuL0ltYWdlRW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogT2VtYmVkTWV0YURhdGE7XG4gIGlzQ29uY2VwdD86IGJvb2xlYW47XG59XG5cbmNvbnN0IFN0eWxlZEZpZ3VyZSA9IHN0eWxlZC5maWd1cmVgXG4gIGlmcmFtZSB7XG4gICAgaGVpZ2h0OiBhdXRvO1xuICB9XG5gO1xuXG5jb25zdCBFeHRlcm5hbEVtYmVkID0gKHsgZW1iZWQsIGlzQ29uY2VwdCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IGZpZ1JlZiA9IHVzZVJlZjxIVE1MRWxlbWVudD4obnVsbCk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBpZnJhbWUgPSBmaWdSZWYuY3VycmVudD8ucXVlcnlTZWxlY3RvcihgaWZyYW1lYCk7XG4gICAgaWYgKGlmcmFtZSkge1xuICAgICAgY29uc3QgW3dpZHRoLCBoZWlnaHRdID0gW3BhcnNlSW50KGlmcmFtZS53aWR0aCksIHBhcnNlSW50KGlmcmFtZS5oZWlnaHQpXTtcbiAgICAgIGlmcmFtZS5zdHlsZS5hc3BlY3RSYXRpbyA9IGAke3dpZHRoID8gd2lkdGggOiAxNn0vJHtoZWlnaHQgPyBoZWlnaHQgOiA5fWA7XG4gICAgICBpZnJhbWUud2lkdGggPSAnJztcbiAgICAgIGlmcmFtZS5oZWlnaHQgPSAnJztcbiAgICB9XG4gIH0sIFtdKTtcbiAgaWYgKGVtYmVkLnN0YXR1cyA9PT0gJ2Vycm9yJykge1xuICAgIHJldHVybiAoXG4gICAgICA8ZmlndXJlIGNsYXNzTmFtZT17aXNDb25jZXB0ID8gJycgOiAnYy1maWd1cmUnfT5cbiAgICAgICAgPGltZyBhbHQ9e3QoJ2V4dGVybmFsLmVycm9yJyl9IHNyYz17ZXJyb3JTdmdTcmN9IC8+XG4gICAgICAgIDxmaWdjYXB0aW9uPnt0KCdleHRlcm5hbC5lcnJvcicpfTwvZmlnY2FwdGlvbj5cbiAgICAgIDwvZmlndXJlPlxuICAgICk7XG4gIH1cblxuICBjb25zdCB7IGVtYmVkRGF0YSwgZGF0YSB9ID0gZW1iZWQ7XG5cbiAgaWYgKGVtYmVkRGF0YS50eXBlID09PSAnZnVsbHNjcmVlbicpIHtcbiAgICBjb25zdCBpbWFnZSA9IHsgc3JjOiBkYXRhLmlmcmFtZUltYWdlPy5pbWFnZVVybCA/PyAnJywgYWx0OiBkYXRhLmlmcmFtZUltYWdlPy5hbHR0ZXh0Py5hbHR0ZXh0ID8/ICcnIH07XG4gICAgcmV0dXJuIChcbiAgICAgIDxGaWd1cmUgdHlwZT1cImZ1bGxcIj5cbiAgICAgICAgPFJlc291cmNlQm94XG4gICAgICAgICAgaW1hZ2U9e2ltYWdlfVxuICAgICAgICAgIHRpdGxlPXtlbWJlZERhdGEudGl0bGUgPz8gJyd9XG4gICAgICAgICAgdXJsPXtlbWJlZERhdGEudXJsfVxuICAgICAgICAgIGNhcHRpb249e2VtYmVkRGF0YS5jYXB0aW9uID8/ICcnfVxuICAgICAgICAgIGJ1dHRvblRleHQ9e3QoJ2xpY2Vuc2Uub3RoZXIuaXRlbUltYWdlLmFyaWFMYWJlbCcpfVxuICAgICAgICAvPlxuICAgICAgPC9GaWd1cmU+XG4gICAgKTtcbiAgfVxuXG4gIGNvbnN0IGZ1bGxDb2x1bW5DbGFzcyA9IGlzQ29uY2VwdCA/ICdjLWZpZ3VyZS0tZnVsbC1jb2x1bW4nIDogJyc7XG4gIGNvbnN0IGNsYXNzZXMgPSBgYy1maWd1cmUgJHtmdWxsQ29sdW1uQ2xhc3N9IGMtZmlndXJlLS1yZXNpemVgO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEZpZ3VyZVxuICAgICAgcmVmPXtmaWdSZWZ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzZXN9XG4gICAgICAvL0B0cy1pZ25vcmVcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9uby11bmtub3duLXByb3BlcnR5XG4gICAgICByZXNpemVpZnJhbWU9XCJ0cnVlXCJcbiAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogZGF0YS5vZW1iZWQuaHRtbCA/PyAnJyB9fVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBFeHRlcm5hbEVtYmVkO1xuIl19 */",
28
28
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
29
29
  });
30
30
  var ExternalEmbed = function ExternalEmbed(_ref) {
@@ -42,6 +42,8 @@ var ExternalEmbed = function ExternalEmbed(_ref) {
42
42
  width = _ref2[0],
43
43
  height = _ref2[1];
44
44
  iframe.style.aspectRatio = "".concat(width ? width : 16, "/").concat(height ? height : 9);
45
+ iframe.width = '';
46
+ iframe.height = '';
45
47
  }
46
48
  }, []);
47
49
  if (embed.status === 'error') {
@@ -8,7 +8,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
8
8
  *
9
9
  */
10
10
 
11
- import { useEffect, useRef } from 'react';
11
+ import React from 'react';
12
12
  import { useTranslation } from 'react-i18next';
13
13
  import { errorSvgSrc } from './ImageEmbed';
14
14
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
@@ -22,7 +22,7 @@ var StyledFigure = /*#__PURE__*/_styled("figure", {
22
22
  } : {
23
23
  name: "9y4sui",
24
24
  styles: "iframe{height:auto;}",
25
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkg1cEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQmtDIiwiZmlsZSI6Ikg1cEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSDVwTWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBlcnJvclN2Z1NyYyB9IGZyb20gJy4vSW1hZ2VFbWJlZCc7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBINXBNZXRhRGF0YTtcbiAgaXNDb25jZXB0PzogYm9vbGVhbjtcbn1cblxuY29uc3QgU3R5bGVkRmlndXJlID0gc3R5bGVkLmZpZ3VyZWBcbiAgaWZyYW1lIHtcbiAgICBoZWlnaHQ6IGF1dG87XG4gIH1cbmA7XG5cbmNvbnN0IEg1cEVtYmVkID0gKHsgZW1iZWQsIGlzQ29uY2VwdCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG5cbiAgY29uc3QgaWZyYW1lUmVmID0gdXNlUmVmPEhUTUxJRnJhbWVFbGVtZW50PihudWxsKTtcbiAgY29uc3QgZmlnUmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGlmcmFtZSA9XG4gICAgICBlbWJlZC5zdGF0dXMgPT09ICdzdWNjZXNzJyAmJiBlbWJlZC5kYXRhLm9lbWJlZCA/IGZpZ1JlZi5jdXJyZW50Py5xdWVyeVNlbGVjdG9yKCdpZnJhbWUnKSA6IGlmcmFtZVJlZi5jdXJyZW50O1xuICAgIGlmIChpZnJhbWUpIHtcbiAgICAgIGNvbnN0IFt3aWR0aCwgaGVpZ2h0XSA9IFtwYXJzZUludChpZnJhbWUud2lkdGgpLCBwYXJzZUludChpZnJhbWUuaGVpZ2h0KV07XG4gICAgICBpZnJhbWUuc3R5bGUuYXNwZWN0UmF0aW8gPSBgJHt3aWR0aCA/IHdpZHRoIDogMTZ9LyR7aGVpZ2h0ID8gaGVpZ2h0IDogOX1gO1xuICAgIH1cbiAgfSwgW2VtYmVkXSk7XG5cbiAgaWYgKGVtYmVkLnN0YXR1cyA9PT0gJ2Vycm9yJykge1xuICAgIHJldHVybiAoXG4gICAgICA8ZmlndXJlIGNsYXNzTmFtZT17aXNDb25jZXB0ID8gJycgOiAnYy1maWd1cmUnfT5cbiAgICAgICAgPGltZyBhbHQ9e3QoJ2g1cC5lcnJvcicpfSBzcmM9e2Vycm9yU3ZnU3JjfSAvPlxuICAgICAgICA8ZmlnY2FwdGlvbj57dCgnaDVwLmVycm9yJyl9PC9maWdjYXB0aW9uPlxuICAgICAgPC9maWd1cmU+XG4gICAgKTtcbiAgfVxuICBjb25zdCBmdWxsQ29sdW1uQ2xhc3MgPSBpc0NvbmNlcHQgPyAnYy1maWd1cmUtLWZ1bGwtY29sdW1uJyA6ICcnO1xuICBjb25zdCBjbGFzc2VzID0gYGMtZmlndXJlICR7ZnVsbENvbHVtbkNsYXNzfSBjLWZpZ3VyZS0tcmVzaXplYDtcblxuICBpZiAoZW1iZWQuZGF0YS5vZW1iZWQpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZEZpZ3VyZVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzZXN9XG4gICAgICAgIHJlZj17ZmlnUmVmfVxuICAgICAgICAvL0B0cy1pZ25vcmVcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L25vLXVua25vd24tcHJvcGVydHlcbiAgICAgICAgcmVzaXplaWZyYW1lPVwidHJ1ZVwiXG4gICAgICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogZW1iZWQuZGF0YS5vZW1iZWQuaHRtbCA/PyAnJyB9fVxuICAgICAgLz5cbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICAvL0B0cy1pZ25vcmVcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3Qvbm8tdW5rbm93bi1wcm9wZXJ0eVxuICAgIDxTdHlsZWRGaWd1cmUgY2xhc3NOYW1lPXtjbGFzc2VzfSByZXNpemVpZnJhbWU9XCJ0cnVlXCI+XG4gICAgICA8aWZyYW1lIHRpdGxlPXtlbWJlZC5lbWJlZERhdGEudXJsfSByZWY9e2lmcmFtZVJlZn0gYXJpYS1sYWJlbD17ZW1iZWQuZW1iZWREYXRhLnVybH0gc3JjPXtlbWJlZC5lbWJlZERhdGEudXJsfSAvPlxuICAgIDwvU3R5bGVkRmlndXJlPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSDVwRW1iZWQ7XG4iXX0= */",
25
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkg1cEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQmtDIiwiZmlsZSI6Ikg1cEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgSDVwTWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IGVycm9yU3ZnU3JjIH0gZnJvbSAnLi9JbWFnZUVtYmVkJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgZW1iZWQ6IEg1cE1ldGFEYXRhO1xuICBpc0NvbmNlcHQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTdHlsZWRGaWd1cmUgPSBzdHlsZWQuZmlndXJlYFxuICBpZnJhbWUge1xuICAgIGhlaWdodDogYXV0bztcbiAgfVxuYDtcblxuY29uc3QgSDVwRW1iZWQgPSAoeyBlbWJlZCwgaXNDb25jZXB0IH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICBpZiAoZW1iZWQuc3RhdHVzID09PSAnZXJyb3InKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxmaWd1cmUgY2xhc3NOYW1lPXtpc0NvbmNlcHQgPyAnJyA6ICdjLWZpZ3VyZSd9PlxuICAgICAgICA8aW1nIGFsdD17dCgnaDVwLmVycm9yJyl9IHNyYz17ZXJyb3JTdmdTcmN9IC8+XG4gICAgICAgIDxmaWdjYXB0aW9uPnt0KCdoNXAuZXJyb3InKX08L2ZpZ2NhcHRpb24+XG4gICAgICA8L2ZpZ3VyZT5cbiAgICApO1xuICB9XG4gIGNvbnN0IGZ1bGxDb2x1bW5DbGFzcyA9IGlzQ29uY2VwdCA/ICdjLWZpZ3VyZS0tZnVsbC1jb2x1bW4nIDogJyc7XG4gIGNvbnN0IGNsYXNzZXMgPSBgYy1maWd1cmUgJHtmdWxsQ29sdW1uQ2xhc3N9IGMtZmlndXJlLS1yZXNpemVgO1xuXG4gIGlmIChlbWJlZC5kYXRhLm9lbWJlZCkge1xuICAgIHJldHVybiA8U3R5bGVkRmlndXJlIGNsYXNzTmFtZT17Y2xhc3Nlc30gZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3sgX19odG1sOiBlbWJlZC5kYXRhLm9lbWJlZC5odG1sID8/ICcnIH19IC8+O1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlndXJlIGNsYXNzTmFtZT17Y2xhc3Nlc30+XG4gICAgICA8aWZyYW1lIHRpdGxlPXtlbWJlZC5lbWJlZERhdGEudXJsfSBhcmlhLWxhYmVsPXtlbWJlZC5lbWJlZERhdGEudXJsfSBzcmM9e2VtYmVkLmVtYmVkRGF0YS51cmx9IC8+XG4gICAgPC9TdHlsZWRGaWd1cmU+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBINXBFbWJlZDtcbiJdfQ== */",
26
26
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
27
27
  });
28
28
  var H5pEmbed = function H5pEmbed(_ref) {
@@ -30,18 +30,6 @@ var H5pEmbed = function H5pEmbed(_ref) {
30
30
  isConcept = _ref.isConcept;
31
31
  var _useTranslation = useTranslation(),
32
32
  t = _useTranslation.t;
33
- var iframeRef = useRef(null);
34
- var figRef = useRef(null);
35
- useEffect(function () {
36
- var _figRef$current;
37
- var iframe = embed.status === 'success' && embed.data.oembed ? (_figRef$current = figRef.current) === null || _figRef$current === void 0 ? void 0 : _figRef$current.querySelector('iframe') : iframeRef.current;
38
- if (iframe) {
39
- var _ref2 = [parseInt(iframe.width), parseInt(iframe.height)],
40
- width = _ref2[0],
41
- height = _ref2[1];
42
- iframe.style.aspectRatio = "".concat(width ? width : 16, "/").concat(height ? height : 9);
43
- }
44
- }, [embed]);
45
33
  if (embed.status === 'error') {
46
34
  return _jsxs("figure", {
47
35
  className: isConcept ? '' : 'c-figure',
@@ -59,29 +47,18 @@ var H5pEmbed = function H5pEmbed(_ref) {
59
47
  var _embed$data$oembed$ht;
60
48
  return _jsx(StyledFigure, {
61
49
  className: classes,
62
- ref: figRef
63
- //@ts-ignore
64
- // eslint-disable-next-line react/no-unknown-property
65
- ,
66
- resizeiframe: "true",
67
50
  dangerouslySetInnerHTML: {
68
51
  __html: (_embed$data$oembed$ht = embed.data.oembed.html) !== null && _embed$data$oembed$ht !== void 0 ? _embed$data$oembed$ht : ''
69
52
  }
70
53
  });
71
54
  }
72
- return (
73
- //@ts-ignore
74
- // eslint-disable-next-line react/no-unknown-property
75
- _jsx(StyledFigure, {
76
- className: classes,
77
- resizeiframe: "true",
78
- children: _jsx("iframe", {
79
- title: embed.embedData.url,
80
- ref: iframeRef,
81
- "aria-label": embed.embedData.url,
82
- src: embed.embedData.url
83
- })
55
+ return _jsx(StyledFigure, {
56
+ className: classes,
57
+ children: _jsx("iframe", {
58
+ title: embed.embedData.url,
59
+ "aria-label": embed.embedData.url,
60
+ src: embed.embedData.url
84
61
  })
85
- );
62
+ });
86
63
  };
87
64
  export default H5pEmbed;
@@ -26,6 +26,8 @@ var ExternalEmbed = function ExternalEmbed(_ref) {
26
26
  _width = _ref2[0],
27
27
  _height = _ref2[1];
28
28
  iframe.style.aspectRatio = "".concat(_width ? _width : 16, "/").concat(_height ? _height : 9);
29
+ iframe.width = '';
30
+ iframe.height = '';
29
31
  }
30
32
  }, []);
31
33
  if (embedData.type === 'fullscreen') {