@ndla/ui 42.0.1 → 42.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/es/AudioPlayer/AudioPlayer.js +15 -15
  2. package/es/Gloss/Gloss.js +137 -0
  3. package/es/Gloss/index.js +9 -0
  4. package/es/Navigation/NavigationBox.js +20 -20
  5. package/es/Programme/ProgrammeSubjects.js +3 -2
  6. package/es/locale/messages-en.js +15 -4
  7. package/es/locale/messages-nb.js +14 -4
  8. package/es/locale/messages-nn.js +15 -5
  9. package/es/locale/messages-se.js +14 -4
  10. package/es/locale/messages-sma.js +14 -4
  11. package/es/model/Transcriptions.js +1 -0
  12. package/es/model/WordClass.js +45 -0
  13. package/es/model/index.js +5 -1
  14. package/lib/AudioPlayer/AudioPlayer.js +15 -15
  15. package/lib/Gloss/Gloss.d.ts +32 -0
  16. package/lib/Gloss/Gloss.js +141 -0
  17. package/lib/Gloss/index.d.ts +8 -0
  18. package/lib/Gloss/index.js +13 -0
  19. package/lib/Navigation/NavigationBox.d.ts +1 -1
  20. package/lib/Navigation/NavigationBox.js +20 -20
  21. package/lib/Programme/ProgrammeSubjects.d.ts +2 -2
  22. package/lib/Programme/ProgrammeSubjects.js +3 -2
  23. package/lib/locale/messages-en.d.ts +12 -1
  24. package/lib/locale/messages-en.js +17 -4
  25. package/lib/locale/messages-nb.d.ts +12 -1
  26. package/lib/locale/messages-nb.js +15 -4
  27. package/lib/locale/messages-nn.d.ts +12 -1
  28. package/lib/locale/messages-nn.js +16 -5
  29. package/lib/locale/messages-se.d.ts +12 -1
  30. package/lib/locale/messages-se.js +15 -4
  31. package/lib/locale/messages-sma.d.ts +12 -1
  32. package/lib/locale/messages-sma.js +15 -4
  33. package/lib/model/Transcriptions.d.ts +11 -0
  34. package/lib/model/Transcriptions.js +5 -0
  35. package/lib/model/WordClass.d.ts +44 -0
  36. package/lib/model/WordClass.js +52 -0
  37. package/lib/model/index.d.ts +4 -0
  38. package/lib/model/index.js +5 -1
  39. package/package.json +15 -15
  40. package/src/AudioPlayer/AudioPlayer.tsx +1 -0
  41. package/src/ContactBlock/Contactblock.stories.tsx +2 -2
  42. package/src/Gloss/Gloss.stories.tsx +108 -0
  43. package/src/Gloss/Gloss.tsx +163 -0
  44. package/src/Gloss/index.tsx +9 -0
  45. package/src/Grid/Grid.stories.tsx +1 -1
  46. package/src/KeyFigure/KeyFigure.stories.tsx +2 -2
  47. package/src/LearningPaths/LearningPathMenu.stories.tsx +2 -2
  48. package/src/MyNdla/Resource/Folder.stories.tsx +1 -1
  49. package/src/Navigation/NavigationBox.tsx +2 -2
  50. package/src/Programme/ProgrammeSubjects.tsx +3 -3
  51. package/src/Resource/BlockResource.stories.tsx +1 -1
  52. package/src/Resource/Resource.stories.tsx +1 -1
  53. package/src/locale/messages-en.ts +46 -1
  54. package/src/locale/messages-nb.ts +46 -1
  55. package/src/locale/messages-nn.ts +47 -2
  56. package/src/locale/messages-se.ts +46 -1
  57. package/src/locale/messages-sma.ts +46 -1
  58. package/src/model/Transcriptions.ts +12 -0
  59. package/src/model/WordClass.ts +45 -0
  60. package/src/model/index.ts +4 -0
@@ -30,7 +30,7 @@ var InfoWrapper = /*#__PURE__*/_styled("div", {
30
30
  label: "InfoWrapper"
31
31
  })("border:1px solid ", colors.brand.lighter, ";border-bottom:0;display:flex;", mq.range({
32
32
  until: breakpoints.tabletWide
33
- }), "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkB8B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
33
+ }), "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkB8B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
34
34
  var ImageWrapper = /*#__PURE__*/_styled("div", {
35
35
  target: "e1wmpntw12",
36
36
  label: "ImageWrapper"
@@ -38,7 +38,7 @@ var ImageWrapper = /*#__PURE__*/_styled("div", {
38
38
  from: breakpoints.desktop
39
39
  }), "{width:260px;height:260px;}", mq.range({
40
40
  until: breakpoints.tabletWide
41
- }), "{max-height:400px;max-width:100%;width:100%;height:auto;img{object-fit:scale-down;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2B+B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
41
+ }), "{max-height:400px;max-width:100%;width:100%;height:auto;img{object-fit:scale-down;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2B+B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
42
42
  var TextWrapper = /*#__PURE__*/_styled("div", {
43
43
  target: "e1wmpntw11",
44
44
  label: "TextWrapper"
@@ -48,27 +48,27 @@ var TextWrapper = /*#__PURE__*/_styled("div", {
48
48
  }), " {\n padding: ").concat(spacing.small, " ").concat(spacing.normal, ";\n }\n ").concat(mq.range({
49
49
  from: breakpoints.tabletWide
50
50
  }), " {\n padding: ").concat(spacing.small, " ").concat(spacing.medium, ";\n }");
51
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2DgD","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
51
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2DgD","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
52
52
  var TitleWrapper = /*#__PURE__*/_styled("div", {
53
53
  target: "e1wmpntw10",
54
54
  label: "TitleWrapper"
55
55
  })(mq.range({
56
56
  from: breakpoints.tabletWide
57
- }), "{display:flex;justify-content:space-between;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyE+B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
57
+ }), "{display:flex;justify-content:space-between;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyE+B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
58
58
  var Title = /*#__PURE__*/_styled("h2", {
59
59
  target: "e1wmpntw9",
60
60
  label: "Title"
61
61
  })(fonts.sizes('22px', '30px'), ";margin:0 0 ", function (props) {
62
62
  return props.hasDescription && "".concat(spacing.small);
63
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAoFmC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
63
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAoFmC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
64
64
  var Subtitle = /*#__PURE__*/_styled("h3", {
65
65
  target: "e1wmpntw8",
66
66
  label: "Subtitle"
67
- })(fonts.sizes('18px', '28px'), ";margin:0;font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyF0B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
67
+ })(fonts.sizes('18px', '28px'), ";margin:0;font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyF0B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
68
68
  var StyledDescription = /*#__PURE__*/_styled("div", {
69
69
  target: "e1wmpntw7",
70
70
  label: "StyledDescription"
71
- })(fonts.sizes('16px', '30px'), ";font-family:", fonts.sans, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA+FoC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
71
+ })(fonts.sizes('16px', '30px'), ";font-family:", fonts.sans, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA+FoC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
72
72
  var LinkToTextVersionWrapper = /*#__PURE__*/_styled("div", {
73
73
  target: "e1wmpntw6",
74
74
  label: "LinkToTextVersionWrapper"
@@ -76,15 +76,15 @@ var LinkToTextVersionWrapper = /*#__PURE__*/_styled("div", {
76
76
  return !props.noMargin && "margin-top: ".concat(spacing.normal, ";\n ");
77
77
  }, " ", mq.range({
78
78
  until: breakpoints.tabletWide
79
- }), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAwG0E","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
79
+ }), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAwG0E","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
80
80
  var TextVersionWrapper = /*#__PURE__*/_styled("div", {
81
81
  target: "e1wmpntw5",
82
82
  label: "TextVersionWrapper"
83
- })("border:1px solid ", colors.brand.lighter, ";border-top:0;", fonts.sizes('16px', '30px'), ";font-family:", fonts.sans, ";&.audio-player-text-version-hidden{display:none;}padding:", spacing.normal, " ", spacing.small, " ", spacing.small, ";", mq.range({
83
+ })("white-space:pre-wrap;border:1px solid ", colors.brand.lighter, ";border-top:0;", fonts.sizes('16px', '30px'), ";font-family:", fonts.sans, ";&.audio-player-text-version-hidden{display:none;}padding:", spacing.normal, " ", spacing.small, " ", spacing.small, ";", mq.range({
84
84
  from: breakpoints.tablet
85
85
  }), "{padding:", spacing.normal, ";}", mq.range({
86
86
  from: breakpoints.tabletWide
87
- }), "{padding:", spacing.normal, " ", spacing.medium, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkHqC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
87
+ }), "{padding:", spacing.normal, " ", spacing.medium, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkHqC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
88
88
  var TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
89
89
  target: "e1wmpntw4",
90
90
  label: "TextVersionHeadingWrapper"
@@ -94,21 +94,21 @@ var TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
94
94
  } : {
95
95
  name: "1f1m9i6",
96
96
  styles: "display:flex;justify-content:space-between;align-items:flex-start",
97
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAmI4C","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
97
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAoI4C","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
98
98
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
99
99
  });
100
100
  var TextVersionHeading = /*#__PURE__*/_styled("h2", {
101
101
  target: "e1wmpntw3",
102
102
  label: "TextVersionHeading"
103
- })("font-weight:", fonts.weight.semibold, ";margin:", spacing.small, " 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyIoC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
103
+ })("font-weight:", fonts.weight.semibold, ";margin:", spacing.small, " 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA0IoC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
104
104
  var LinkButton = /*#__PURE__*/_styled(ButtonV2, {
105
105
  target: "e1wmpntw2",
106
106
  label: "LinkButton"
107
- })("box-shadow:none;padding-left:0;padding-right:4px;min-height:", spacing.medium, ";", fonts.sizes('16px', '25px'), ";flex:0 0 auto;&:hover,&:focus{box-shadow:", colors.link, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA8ImC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
107
+ })("box-shadow:none;padding-left:0;padding-right:4px;min-height:", spacing.medium, ";", fonts.sizes('16px', '25px'), ";flex:0 0 auto;&:hover,&:focus{box-shadow:", colors.link, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA+ImC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
108
108
  var CloseText = /*#__PURE__*/_styled("span", {
109
109
  target: "e1wmpntw1",
110
110
  label: "CloseText"
111
- })("display:inline-block;margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2J6B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
111
+ })("display:inline-block;margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA4J6B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
112
112
  var TextVersionText = /*#__PURE__*/_styled("div", {
113
113
  target: "e1wmpntw0",
114
114
  label: "TextVersionText"
@@ -118,7 +118,7 @@ var TextVersionText = /*#__PURE__*/_styled("div", {
118
118
  } : {
119
119
  name: "j8dnu6",
120
120
  styles: "max-width:670px",
121
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAgKkC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
121
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAiKkC","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 React, { ReactNode, useMemo, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ButtonV2 } from '@ndla/button';\nimport { Cross as CrossIcon } from '@ndla/icons/action';\nimport { useTranslation } from 'react-i18next';\nimport SafeLink from '@ndla/safelink';\nimport Controls from './Controls';\nimport SpeechControl from './SpeechControl';\n\nconst InfoWrapper = styled.div`\n  border: 1px solid ${colors.brand.lighter};\n  border-bottom: 0;\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: block;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  display: flex;\n  align-items: center;\n  flex: 1 0 auto;\n\n  width: 200px;\n  height: 200px;\n\n  img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 260px;\n    height: 260px;\n  }\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    max-height: 400px;\n    max-width: 100%;\n    width: 100%;\n    height: auto;\n    img {\n      object-fit: scale-down;\n    }\n  }\n`;\n\ntype TextWrapperProps = {\n  hasImage?: boolean;\n};\n\nconst TextWrapper = styled.div<TextWrapperProps>`\n  padding: ${spacing.small};\n  width: 100%;\n\n  ${(props) =>\n    props.hasImage &&\n    `${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.small} ${spacing.medium};\n  }`}\n`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\ntype TitleProps = {\n  hasDescription?: boolean;\n};\n\nconst Title = styled.h2<TitleProps>`\n  ${fonts.sizes('22px', '30px')};\n  margin: 0 0 ${(props) => props.hasDescription && `${spacing.small}`};\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes('18px', '28px')};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\ntype LinkToTextVersionWrapperProps = {\n  noMargin?: boolean;\n};\nconst LinkToTextVersionWrapper = styled.div<LinkToTextVersionWrapperProps>`\n  ${(props) =>\n    !props.noMargin &&\n    `margin-top: ${spacing.normal};\n  `}\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    margin: ${spacing.small} 0;\n  }\n`;\n\nconst TextVersionWrapper = styled.div`\n  white-space: pre-wrap;\n  border: 1px solid ${colors.brand.lighter};\n  border-top: 0;\n  ${fonts.sizes('16px', '30px')};\n  font-family: ${fonts.sans};\n  &.audio-player-text-version-hidden {\n    display: none;\n  }\n  padding: ${spacing.normal} ${spacing.small} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal};\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: ${spacing.normal} ${spacing.medium};\n  }\n`;\n\nconst TextVersionHeadingWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-start;\n`;\n\nconst TextVersionHeading = styled.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes('16px', '25px')};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n`;\n\nconst DESCRIPTION_MAX_LENGTH = 200;\n\ntype Props = {\n  src: string;\n  title: string;\n  subtitle?: {\n    title: string;\n    url?: string;\n  };\n  speech?: boolean;\n  description?: string;\n  textVersion?: ReactNode;\n  img?: {\n    url: string;\n    alt: string;\n  };\n  staticRenderId?: string;\n};\n\nconst AudioPlayer = ({ src, title, subtitle, speech, description, img, textVersion, staticRenderId }: Props) => {\n  const { t } = useTranslation();\n  const [showTextVersion, setShowTextVersion] = useState(false);\n  const [showFullDescription, setShowFullDescription] = useState(false);\n  const truncatedDescription = useMemo(() => description?.slice(0, DESCRIPTION_MAX_LENGTH), [description]);\n\n  if (speech) {\n    return (\n      <div data-audio-player={1} data-speech={1} data-src={src} data-title={title}>\n        <SpeechControl src={src} title={title} />\n      </div>\n    );\n  }\n\n  const toggleTextVersion = () => {\n    setShowTextVersion(!showTextVersion);\n  };\n\n  type TextVersionComponentProps = {\n    noMargin?: boolean;\n  };\n  const TextVersionComponent = ({ noMargin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper noMargin={noMargin}>\n      <ButtonV2 size=\"normal\" shape=\"pill\" onClick={toggleTextVersion} data-audio-text-button-id={staticRenderId}>\n        {t('audio.textVersion.heading')}\n      </ButtonV2>\n    </LinkToTextVersionWrapper>\n  );\n\n  return (\n    <>\n      <InfoWrapper>\n        {img && (\n          <ImageWrapper>\n            <img src={img.url} alt={img.alt} />\n          </ImageWrapper>\n        )}\n        <TextWrapper hasImage={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title hasDescription={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent noMargin />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? 'readLessDescriptionLabel' : 'readMoreDescriptionLabel'}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent />}\n        </TextWrapper>\n      </InfoWrapper>\n      <div data-audio-player={1} data-src={src} data-title={title}>\n        <Controls src={src} title={title} />\n      </div>\n      {textVersion && (showTextVersion || staticRenderId) && (\n        <TextVersionWrapper id={staticRenderId} hidden={!!staticRenderId}>\n          <TextVersionHeadingWrapper>\n            <TextVersionHeading>{t('audio.textVersion.heading')}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: '20px', height: '20px' }} />\n              <CloseText>{t('audio.textVersion.close')}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
122
122
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
123
123
  });
124
124
  var DESCRIPTION_MAX_LENGTH = 200;