@ndla/ui 55.0.2-alpha.0 → 55.0.3-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -23,15 +23,15 @@ const InfoWrapper = /*#__PURE__*/_styled("div", {
|
|
|
23
23
|
label: "InfoWrapper"
|
|
24
24
|
})("border:1px solid ", colors.brand.lighter, ";border-bottom:0;display:flex;", mq.range({
|
|
25
25
|
until: breakpoints.tabletWide
|
|
26
|
-
}), "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
26
|
+
}), "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAmB8B","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
27
27
|
const ImageWrapper = /*#__PURE__*/_styled("div", {
|
|
28
28
|
target: "e1wmpntw10",
|
|
29
29
|
label: "ImageWrapper"
|
|
30
|
-
})("display:flex;align-items:center;flex:1 0 auto;width:200px;height:200px;img{width:100%;height:100%;object-fit:cover;}", mq.range({
|
|
30
|
+
})("display:flex;align-items:center;flex:1 0 auto;width:200px;height:200px;overflow:hidden;img{width:100%;height:100%;object-fit:cover;}", mq.range({
|
|
31
31
|
from: breakpoints.desktop
|
|
32
32
|
}), "{width:260px;height:260px;}", mq.range({
|
|
33
33
|
until: breakpoints.tabletWide
|
|
34
|
-
}), "{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":"AA4B+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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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
|
+
}), "{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":"AA4B+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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
35
35
|
const TextWrapper = /*#__PURE__*/_styled("div", {
|
|
36
36
|
target: "e1wmpntw9",
|
|
37
37
|
label: "TextWrapper"
|
|
@@ -39,23 +39,23 @@ const TextWrapper = /*#__PURE__*/_styled("div", {
|
|
|
39
39
|
from: breakpoints.tablet
|
|
40
40
|
}), "{padding:", spacing.small, " ", spacing.normal, ";}", mq.range({
|
|
41
41
|
from: breakpoints.tabletWide
|
|
42
|
-
}), "{padding:", spacing.small, " ", spacing.medium, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42
|
+
}), "{padding:", spacing.small, " ", spacing.medium, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyD8B","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
43
43
|
const TitleWrapper = /*#__PURE__*/_styled("div", {
|
|
44
44
|
target: "e1wmpntw8",
|
|
45
45
|
label: "TitleWrapper"
|
|
46
46
|
})(mq.range({
|
|
47
47
|
from: breakpoints.tabletWide
|
|
48
|
-
}), "{display:flex;justify-content:space-between;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
48
|
+
}), "{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":"AAsE+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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
49
49
|
const Title = /*#__PURE__*/_styled(Heading, {
|
|
50
50
|
target: "e1wmpntw7",
|
|
51
51
|
label: "Title"
|
|
52
|
-
})("&[data-has-desc=\"true\"]{margin:", spacing.xsmall, " 0 ", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA4E6B","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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
|
+
})("&[data-has-desc=\"true\"]{margin:", spacing.xsmall, " 0 ", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA6E6B","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
53
53
|
const LinkToTextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
54
54
|
target: "e1wmpntw6",
|
|
55
55
|
label: "LinkToTextVersionWrapper"
|
|
56
56
|
})("&[data-margin=\"true\"]{margin-top:", spacing.small, ";}", mq.range({
|
|
57
57
|
until: breakpoints.tabletWide
|
|
58
|
-
}), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
58
|
+
}), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAmF2C","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
59
59
|
const TextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
60
60
|
target: "e1wmpntw5",
|
|
61
61
|
label: "TextVersionWrapper"
|
|
@@ -63,7 +63,7 @@ const TextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
|
63
63
|
from: breakpoints.tablet
|
|
64
64
|
}), "{padding:", spacing.normal, ";}", mq.range({
|
|
65
65
|
from: breakpoints.tabletWide
|
|
66
|
-
}), "{padding:", spacing.normal, " ", spacing.medium, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
66
|
+
}), "{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":"AA4FqC","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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
67
|
const TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
68
68
|
target: "e1wmpntw4",
|
|
69
69
|
label: "TextVersionHeadingWrapper"
|
|
@@ -73,21 +73,21 @@ const TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
|
73
73
|
} : {
|
|
74
74
|
name: "1f1m9i6",
|
|
75
75
|
styles: "display:flex;justify-content:space-between;align-items:flex-start",
|
|
76
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
76
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA6G4C","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */",
|
|
77
77
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
78
78
|
});
|
|
79
79
|
const TextVersionHeading = /*#__PURE__*/_styled(Heading, {
|
|
80
80
|
target: "e1wmpntw3",
|
|
81
81
|
label: "TextVersionHeading"
|
|
82
|
-
})("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":"AAkH0C","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
82
|
+
})("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":"AAmH0C","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
83
83
|
const LinkButton = /*#__PURE__*/_styled(ButtonV2, {
|
|
84
84
|
target: "e1wmpntw2",
|
|
85
85
|
label: "LinkButton"
|
|
86
|
-
})("box-shadow:none;padding-left:0;padding-right:", spacing.xxsmall, ";min-height:", spacing.medium, ";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":"AAuHmC","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
86
|
+
})("box-shadow:none;padding-left:0;padding-right:", spacing.xxsmall, ";min-height:", spacing.medium, ";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":"AAwHmC","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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
87
|
const CloseText = /*#__PURE__*/_styled("span", {
|
|
88
88
|
target: "e1wmpntw1",
|
|
89
89
|
label: "CloseText"
|
|
90
|
-
})("display:inline-block;margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
90
|
+
})("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":"AAoI6B","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */"));
|
|
91
91
|
const TextVersionText = /*#__PURE__*/_styled("div", {
|
|
92
92
|
target: "e1wmpntw0",
|
|
93
93
|
label: "TextVersionText"
|
|
@@ -97,7 +97,7 @@ const TextVersionText = /*#__PURE__*/_styled("div", {
|
|
|
97
97
|
} : {
|
|
98
98
|
name: "t48xa9",
|
|
99
99
|
styles: "max-width:670px;& span>*{white-space:pre-wrap;}",
|
|
100
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
100
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyIkC","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 { ReactNode, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport styled from \"@emotion/styled\";\nimport { ButtonV2 } from \"@ndla/button\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { Cross as CrossIcon } from \"@ndla/icons/action\";\nimport { SafeLink } from \"@ndla/safelink\";\nimport { Heading, Text } from \"@ndla/typography\";\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  overflow: hidden;\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\nconst TextWrapper = styled.div`\n  padding: ${spacing.small};\n  width: 100%;\n  &[data-has-image=\"true\"] {\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`;\n\nconst TitleWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    display: flex;\n    justify-content: space-between;\n  }\n`;\n\nconst Title = styled(Heading)`\n  &[data-has-desc=\"true\"] {\n    margin: ${spacing.xsmall} 0 ${spacing.small};\n  }\n`;\n\nconst LinkToTextVersionWrapper = styled.div`\n  &[data-margin=\"true\"] {\n    margin-top: ${spacing.small};\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(Heading)`\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: ${spacing.xxsmall};\n  min-height: ${spacing.medium};\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  & span > * {\n    white-space: pre-wrap;\n  }\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    margin?: boolean;\n  };\n  const TextVersionComponent = ({ margin }: TextVersionComponentProps) => (\n    <LinkToTextVersionWrapper data-margin={margin}>\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 data-has-image={!!img}>\n          <TitleWrapper>\n            <div>\n              {subtitle?.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle?.title}\n              <Title element=\"h3\" headingStyle=\"h4\" margin=\"none\" data-has-desc={!!description}>\n                {title}\n              </Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <Text element=\"p\" textStyle=\"meta-text-small\" margin=\"none\">\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            </Text>\n          )}\n          {textVersion && img && <TextVersionComponent margin />}\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 element=\"h3\" headingStyle=\"h2\" margin=\"small\">\n              {t(\"audio.textVersion.heading\")}\n            </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"]} */",
|
|
101
101
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
102
102
|
});
|
|
103
103
|
const DESCRIPTION_MAX_LENGTH = 200;
|