@ndla/ui 50.9.7 → 50.9.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/AudioPlayer/AudioPlayer.js +34 -34
- package/es/Embed/ContentLinkEmbed.js +2 -2
- package/es/Embed/IframeEmbed.js +11 -4
- package/es/Embed/UuDisclaimerEmbed.js +75 -0
- package/es/Embed/index.js +2 -1
- package/es/Messages/MessageBox.js +6 -6
- package/es/RelatedArticleList/RelatedArticleList.js +8 -8
- package/es/index.js +1 -1
- package/es/locale/messages-en.js +3 -0
- package/es/locale/messages-nb.js +3 -0
- package/es/locale/messages-nn.js +3 -0
- package/es/locale/messages-se.js +3 -0
- package/es/locale/messages-sma.js +3 -0
- package/lib/AudioPlayer/AudioPlayer.js +34 -34
- package/lib/Embed/ContentLinkEmbed.js +2 -2
- package/lib/Embed/IframeEmbed.js +12 -4
- package/lib/Embed/UuDisclaimerEmbed.d.ts +15 -0
- package/lib/Embed/UuDisclaimerEmbed.js +78 -0
- package/lib/Embed/index.d.ts +1 -0
- package/lib/Embed/index.js +7 -0
- package/lib/Messages/MessageBox.d.ts +1 -1
- package/lib/Messages/MessageBox.js +6 -6
- package/lib/RelatedArticleList/RelatedArticleList.js +8 -8
- package/lib/index.d.ts +1 -1
- package/lib/index.js +6 -0
- package/lib/locale/messages-en.d.ts +3 -0
- package/lib/locale/messages-en.js +3 -0
- package/lib/locale/messages-nb.d.ts +3 -0
- package/lib/locale/messages-nb.js +3 -0
- package/lib/locale/messages-nn.d.ts +3 -0
- package/lib/locale/messages-nn.js +3 -0
- package/lib/locale/messages-se.d.ts +3 -0
- package/lib/locale/messages-se.js +3 -0
- package/lib/locale/messages-sma.d.ts +3 -0
- package/lib/locale/messages-sma.js +3 -0
- package/package.json +12 -12
- package/src/AudioPlayer/AudioPlayer.tsx +13 -27
- package/src/CampaignBlock/CampaignBlock.stories.tsx +15 -0
- package/src/Embed/BrightcoveEmbed.stories.tsx +1 -1
- package/src/Embed/ContentLinkEmbed.tsx +1 -1
- package/src/Embed/ExternalEmbed.stories.tsx +93 -0
- package/src/Embed/IframeEmbed.tsx +8 -3
- package/src/Embed/UuDisclaimerEmbed.stories.tsx +150 -0
- package/src/Embed/UuDisclaimerEmbed.tsx +62 -0
- package/src/Embed/index.ts +1 -0
- package/src/Messages/MessageBox.tsx +1 -1
- package/src/RelatedArticleList/RelatedArticleList.tsx +1 -1
- package/src/index.ts +1 -0
- package/src/locale/messages-en.ts +3 -0
- package/src/locale/messages-nb.ts +3 -0
- package/src/locale/messages-nn.ts +3 -0
- package/src/locale/messages-se.ts +3 -0
- package/src/locale/messages-sma.ts +3 -0
|
@@ -14,57 +14,50 @@ import { ButtonV2 } from "@ndla/button";
|
|
|
14
14
|
import { breakpoints, colors, fonts, mq, spacing } from "@ndla/core";
|
|
15
15
|
import { Cross as CrossIcon } from "@ndla/icons/action";
|
|
16
16
|
import SafeLink from "@ndla/safelink";
|
|
17
|
+
import { Heading, Text } from "@ndla/typography";
|
|
17
18
|
import Controls from "./Controls";
|
|
18
19
|
import SpeechControl from "./SpeechControl";
|
|
19
20
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
20
21
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
21
22
|
import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
22
23
|
const InfoWrapper = /*#__PURE__*/_styled("div", {
|
|
23
|
-
target: "
|
|
24
|
+
target: "e1wmpntw11",
|
|
24
25
|
label: "InfoWrapper"
|
|
25
26
|
})("border:1px solid ", colors.brand.lighter, ";border-bottom:0;display:flex;", mq.range({
|
|
26
27
|
until: breakpoints.tabletWide
|
|
27
|
-
}), "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkB8B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { 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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
28
|
+
}), "{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\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: 4px;\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 && 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"]} */"));
|
|
28
29
|
const ImageWrapper = /*#__PURE__*/_styled("div", {
|
|
29
|
-
target: "
|
|
30
|
+
target: "e1wmpntw10",
|
|
30
31
|
label: "ImageWrapper"
|
|
31
32
|
})("display:flex;align-items:center;flex:1 0 auto;width:200px;height:200px;img{width:100%;height:100%;object-fit:cover;}", mq.range({
|
|
32
33
|
from: breakpoints.desktop
|
|
33
34
|
}), "{width:260px;height:260px;}", mq.range({
|
|
34
35
|
until: breakpoints.tabletWide
|
|
35
|
-
}), "{max-height:400px;max-width:100%;width:100%;height:auto;img{object-fit:scale-down;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2B+B","file":"AudioPlayer.tsx","sourcesContent":["/**\n * Copyright (c) 2017-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { 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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
36
|
+
}), "{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: 4px;\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 && 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"]} */"));
|
|
36
37
|
const TextWrapper = /*#__PURE__*/_styled("div", {
|
|
37
|
-
target: "
|
|
38
|
+
target: "e1wmpntw9",
|
|
38
39
|
label: "TextWrapper"
|
|
39
40
|
})("padding:", spacing.small, ";width:100%;&[data-has-image=\"true\"]{", mq.range({
|
|
40
41
|
from: breakpoints.tablet
|
|
41
42
|
}), "{padding:", spacing.small, " ", spacing.normal, ";}", mq.range({
|
|
42
43
|
from: breakpoints.tabletWide
|
|
43
|
-
}), "{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":"AAuD8B","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
44
|
+
}), "{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":"AAwD8B","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: 4px;\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 && 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"]} */"));
|
|
44
45
|
const TitleWrapper = /*#__PURE__*/_styled("div", {
|
|
45
|
-
target: "
|
|
46
|
+
target: "e1wmpntw8",
|
|
46
47
|
label: "TitleWrapper"
|
|
47
48
|
})(mq.range({
|
|
48
49
|
from: breakpoints.tabletWide
|
|
49
|
-
}), "{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":"AAoE+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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
50
|
-
const Title = /*#__PURE__*/_styled(
|
|
51
|
-
target: "e1wmpntw9",
|
|
52
|
-
label: "Title"
|
|
53
|
-
})(fonts.sizes("22px", "30px"), ";margin:0px;&[data-has-desc=\"true\"]{margin:0 0 ", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA2EuB","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
54
|
-
const Subtitle = /*#__PURE__*/_styled("h3", {
|
|
55
|
-
target: "e1wmpntw8",
|
|
56
|
-
label: "Subtitle"
|
|
57
|
-
})(fonts.sizes("18px", "28px"), ";margin:0;font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAmF0B","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
58
|
-
const StyledDescription = /*#__PURE__*/_styled("div", {
|
|
50
|
+
}), "{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":"AAqE+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: 4px;\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 && 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"]} */"));
|
|
51
|
+
const Title = /*#__PURE__*/_styled(Heading, {
|
|
59
52
|
target: "e1wmpntw7",
|
|
60
|
-
label: "
|
|
61
|
-
})(fonts.sizes("16px", "30px"), ";font-family:", fonts.sans, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyFoC","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
53
|
+
label: "Title"
|
|
54
|
+
})("&[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: 4px;\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 && 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"]} */"));
|
|
62
55
|
const LinkToTextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
63
56
|
target: "e1wmpntw6",
|
|
64
57
|
label: "LinkToTextVersionWrapper"
|
|
65
58
|
})("&[data-margin=\"true\"]{margin-top:", spacing.small, ";}", mq.range({
|
|
66
59
|
until: breakpoints.tabletWide
|
|
67
|
-
}), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA+F2C","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
60
|
+
}), "{margin:", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAkF2C","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: 4px;\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 && 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"]} */"));
|
|
68
61
|
const TextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
69
62
|
target: "e1wmpntw5",
|
|
70
63
|
label: "TextVersionWrapper"
|
|
@@ -72,7 +65,7 @@ const TextVersionWrapper = /*#__PURE__*/_styled("div", {
|
|
|
72
65
|
from: breakpoints.tablet
|
|
73
66
|
}), "{padding:", spacing.normal, ";}", mq.range({
|
|
74
67
|
from: breakpoints.tabletWide
|
|
75
|
-
}), "{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":"AAwGqC","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
68
|
+
}), "{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":"AA2FqC","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: 4px;\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 && 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"]} */"));
|
|
76
69
|
const TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
77
70
|
target: "e1wmpntw4",
|
|
78
71
|
label: "TextVersionHeadingWrapper"
|
|
@@ -82,21 +75,21 @@ const TextVersionHeadingWrapper = /*#__PURE__*/_styled("div", {
|
|
|
82
75
|
} : {
|
|
83
76
|
name: "1f1m9i6",
|
|
84
77
|
styles: "display:flex;justify-content:space-between;align-items:flex-start",
|
|
85
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAyH4C","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
|
|
78
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AA4G4C","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: 4px;\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 && 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
79
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
87
80
|
});
|
|
88
|
-
const TextVersionHeading = /*#__PURE__*/_styled(
|
|
81
|
+
const TextVersionHeading = /*#__PURE__*/_styled(Heading, {
|
|
89
82
|
target: "e1wmpntw3",
|
|
90
83
|
label: "TextVersionHeading"
|
|
91
|
-
})("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":"AA+HoC","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
84
|
+
})("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: 4px;\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 && 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"]} */"));
|
|
92
85
|
const LinkButton = /*#__PURE__*/_styled(ButtonV2, {
|
|
93
86
|
target: "e1wmpntw2",
|
|
94
87
|
label: "LinkButton"
|
|
95
|
-
})("box-shadow:none;padding-left:0;padding-right:4px;min-height:", spacing.medium, ";", fonts.sizes("16px", "25px"), ";flex:0 0 auto;&:hover,&:focus{box-shadow:", colors.link, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAoImC","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
88
|
+
})("box-shadow:none;padding-left:0;padding-right:4px;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: 4px;\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 && 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"]} */"));
|
|
96
89
|
const CloseText = /*#__PURE__*/_styled("span", {
|
|
97
90
|
target: "e1wmpntw1",
|
|
98
91
|
label: "CloseText"
|
|
99
|
-
})("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":"AAiJ6B","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */"));
|
|
92
|
+
})("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":"AAmI6B","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: 4px;\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 && 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"]} */"));
|
|
100
93
|
const TextVersionText = /*#__PURE__*/_styled("div", {
|
|
101
94
|
target: "e1wmpntw0",
|
|
102
95
|
label: "TextVersionText"
|
|
@@ -106,7 +99,7 @@ const TextVersionText = /*#__PURE__*/_styled("div", {
|
|
|
106
99
|
} : {
|
|
107
100
|
name: "t48xa9",
|
|
108
101
|
styles: "max-width:670px;& span>*{white-space:pre-wrap;}",
|
|
109
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAsJkC","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 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.h2`\n  ${fonts.sizes(\"22px\", \"30px\")};\n  margin: 0px;\n  &[data-has-desc=\"true\"] {\n    margin: 0 0 ${spacing.small};\n  }\n`;\n\nconst Subtitle = styled.h3`\n  ${fonts.sizes(\"18px\", \"28px\")};\n  margin: 0;\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledDescription = styled.div`\n  ${fonts.sizes(\"16px\", \"30px\")};\n  font-family: ${fonts.sans};\n  margin: 0;\n`;\n\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.h2`\n  font-weight: ${fonts.weight.semibold};\n  margin: ${spacing.small} 0 ${spacing.normal};\n`;\n\nconst LinkButton = styled(ButtonV2)`\n  box-shadow: none;\n  padding-left: 0;\n  padding-right: 4px;\n  min-height: ${spacing.medium};\n  ${fonts.sizes(\"16px\", \"25px\")};\n  flex: 0 0 auto;\n  &:hover,\n  &:focus {\n    box-shadow: ${colors.link};\n  }\n`;\n\nconst CloseText = styled.span`\n  display: inline-block;\n  margin-left: ${spacing.xsmall};\n`;\n\nconst TextVersionText = styled.div`\n  max-width: 670px;\n  & 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 && (\n                <Subtitle>\n                  {subtitle.url ? <SafeLink to={subtitle.url}>{subtitle.title}</SafeLink> : subtitle.title}\n                </Subtitle>\n              )}\n              <Title data-has-desc={!!description}>{title}</Title>\n            </div>\n            {textVersion && !img && <TextVersionComponent />}\n          </TitleWrapper>\n          {description && (\n            <StyledDescription>\n              {showFullDescription || description.length < DESCRIPTION_MAX_LENGTH\n                ? description\n                : `${truncatedDescription}...`}\n              <ButtonV2 variant=\"link\" onClick={() => setShowFullDescription((p) => !p)}>\n                {t(`audio.${showFullDescription ? \"readLessDescriptionLabel\" : \"readMoreDescriptionLabel\"}`)}\n              </ButtonV2>\n            </StyledDescription>\n          )}\n          {textVersion && img && <TextVersionComponent 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>{t(\"audio.textVersion.heading\")}</TextVersionHeading>\n            <LinkButton\n              variant=\"link\"\n              size=\"normal\"\n              onClick={toggleTextVersion}\n              data-audio-text-button-id={staticRenderId}\n            >\n              <CrossIcon style={{ width: \"20px\", height: \"20px\" }} />\n              <CloseText>{t(\"audio.textVersion.close\")}</CloseText>\n            </LinkButton>\n          </TextVersionHeadingWrapper>\n          <TextVersionText>{textVersion}</TextVersionText>\n        </TextVersionWrapper>\n      )}\n    </>\n  );\n};\n\nexport default AudioPlayer;\n"]} */",
|
|
102
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AudioPlayer.tsx"],"names":[],"mappings":"AAwIkC","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: 4px;\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 && 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"]} */",
|
|
110
103
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
111
104
|
});
|
|
112
105
|
const DESCRIPTION_MAX_LENGTH = 200;
|
|
@@ -168,17 +161,21 @@ const AudioPlayer = _ref => {
|
|
|
168
161
|
"data-has-image": !!img,
|
|
169
162
|
children: [_jsxs(TitleWrapper, {
|
|
170
163
|
children: [_jsxs("div", {
|
|
171
|
-
children: [subtitle && _jsx(
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
164
|
+
children: [subtitle && subtitle.url ? _jsx(SafeLink, {
|
|
165
|
+
to: subtitle.url,
|
|
166
|
+
children: subtitle.title
|
|
167
|
+
}) : subtitle?.title, _jsx(Title, {
|
|
168
|
+
element: "h3",
|
|
169
|
+
headingStyle: "h4",
|
|
170
|
+
margin: "none",
|
|
177
171
|
"data-has-desc": !!description,
|
|
178
172
|
children: title
|
|
179
173
|
})]
|
|
180
174
|
}), textVersion && !img && _jsx(TextVersionComponent, {})]
|
|
181
|
-
}), description && _jsxs(
|
|
175
|
+
}), description && _jsxs(Text, {
|
|
176
|
+
element: "p",
|
|
177
|
+
textStyle: "meta-text-small",
|
|
178
|
+
margin: "none",
|
|
182
179
|
children: [showFullDescription || description.length < DESCRIPTION_MAX_LENGTH ? description : `${truncatedDescription}...`, _jsx(ButtonV2, {
|
|
183
180
|
variant: "link",
|
|
184
181
|
onClick: () => setShowFullDescription(p => !p),
|
|
@@ -201,6 +198,9 @@ const AudioPlayer = _ref => {
|
|
|
201
198
|
hidden: !!staticRenderId,
|
|
202
199
|
children: [_jsxs(TextVersionHeadingWrapper, {
|
|
203
200
|
children: [_jsx(TextVersionHeading, {
|
|
201
|
+
element: "h3",
|
|
202
|
+
headingStyle: "h2",
|
|
203
|
+
margin: "small",
|
|
204
204
|
children: t("audio.textVersion.heading")
|
|
205
205
|
}), _jsxs(LinkButton, {
|
|
206
206
|
variant: "link",
|