@ndla/ui 30.2.3 → 30.3.1
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/MultidisciplinarySubject/MultidisciplinarySubject.js +11 -8
- package/es/Resource/BlockResource.js +8 -8
- package/es/ToolboxPage/ToolboxInfo.js +6 -3
- package/es/Topic/Topic.js +24 -21
- package/es/TreeStructure/TreeStructure.js +8 -8
- package/lib/MultidisciplinarySubject/MultidisciplinarySubject.d.ts +2 -1
- package/lib/MultidisciplinarySubject/MultidisciplinarySubject.js +11 -8
- package/lib/Resource/BlockResource.js +8 -8
- package/lib/ToolboxPage/ToolboxInfo.d.ts +4 -3
- package/lib/ToolboxPage/ToolboxInfo.js +6 -3
- package/lib/Topic/Topic.d.ts +2 -1
- package/lib/Topic/Topic.js +24 -21
- package/lib/TreeStructure/TreeStructure.d.ts +1 -1
- package/lib/TreeStructure/TreeStructure.js +8 -8
- package/package.json +2 -2
- package/src/MultidisciplinarySubject/MultidisciplinarySubject.tsx +5 -2
- package/src/Resource/BlockResource.tsx +1 -1
- package/src/ToolboxPage/ToolboxInfo.tsx +7 -4
- package/src/Topic/Topic.tsx +3 -1
- package/src/TreeStructure/TreeStructure.tsx +1 -1
package/es/Topic/Topic.js
CHANGED
|
@@ -36,8 +36,8 @@ var Wrapper = /*#__PURE__*/_styled("section", {
|
|
|
36
36
|
from: breakpoints.desktop
|
|
37
37
|
}), "{padding:40px 80px;}", mq.range({
|
|
38
38
|
from: '1180px'
|
|
39
|
-
}), "{padding:60px 160px;};label:Wrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAmCO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
40
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAgC0C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
39
|
+
}), "{padding:60px 160px;};label:Wrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAmCO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
40
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAgC0C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
41
41
|
|
|
42
42
|
var TopicHeaderVisualElementWrapper = /*#__PURE__*/_styled("div", {
|
|
43
43
|
target: "e111uita13",
|
|
@@ -46,7 +46,7 @@ var TopicHeaderVisualElementWrapper = /*#__PURE__*/_styled("div", {
|
|
|
46
46
|
from: breakpoints.mobileWide
|
|
47
47
|
}), "{width:150px;height:150px;}", mq.range({
|
|
48
48
|
from: breakpoints.tablet
|
|
49
|
-
}), "{width:200px;height:200px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAiDkD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
49
|
+
}), "{width:200px;height:200px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAiDkD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
50
50
|
|
|
51
51
|
var ShowVisualElementWrapper = /*#__PURE__*/_styled("div", {
|
|
52
52
|
target: "e111uita12",
|
|
@@ -57,31 +57,31 @@ var ShowVisualElementWrapper = /*#__PURE__*/_styled("div", {
|
|
|
57
57
|
} : {
|
|
58
58
|
name: "123g6v6",
|
|
59
59
|
styles: "border-radius:50%;width:100%;height:100%;overflow:hidden;-webkit-mask-image:-webkit-radial-gradient(white, black)",
|
|
60
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAiE2C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
60
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAiE2C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
61
61
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
62
62
|
});
|
|
63
63
|
|
|
64
64
|
var VisualElementButton = /*#__PURE__*/_styled(Button, {
|
|
65
65
|
target: "e111uita11",
|
|
66
66
|
label: "VisualElementButton"
|
|
67
|
-
})("color:", colors.brand.secondary, ";width:100%;height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAyE0C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
67
|
+
})("color:", colors.brand.secondary, ";width:100%;height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAyE0C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
68
68
|
|
|
69
69
|
var TopicHeaderImage = /*#__PURE__*/_styled("img", {
|
|
70
70
|
target: "e111uita10",
|
|
71
71
|
label: "TopicHeaderImage"
|
|
72
|
-
})("border-radius:50%;width:100%;height:100%;object-fit:cover;transition:transform ", animations.durations.fast, ";", VisualElementButton, ":hover &{transform:scale(1.1);opacity:1.2;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+EmC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
72
|
+
})("border-radius:50%;width:100%;height:100%;object-fit:cover;transition:transform ", animations.durations.fast, ";", VisualElementButton, ":hover &{transform:scale(1.1);opacity:1.2;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+EmC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
73
73
|
|
|
74
74
|
var ExpandVisualElementButton = /*#__PURE__*/_styled("span", {
|
|
75
75
|
target: "e111uita9",
|
|
76
76
|
label: "ExpandVisualElementButton"
|
|
77
77
|
})("position:absolute;right:-10px;bottom:-4px;transition:all ", animations.durations.fast, ";", VisualElementButton, ":hover &{right:10px;}", mq.range({
|
|
78
78
|
from: breakpoints.mobileWide
|
|
79
|
-
}), "{right:0;bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA2F6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
79
|
+
}), "{right:0;bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA2F6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
80
80
|
|
|
81
81
|
var TopicHeaderOverlay = /*#__PURE__*/_styled("div", {
|
|
82
82
|
target: "e111uita8",
|
|
83
83
|
label: "TopicHeaderOverlay"
|
|
84
|
-
})("background:black;opacity:0.05;position:absolute;top:0;left:0;bottom:0;right:0;border-radius:50%;transition:opacity ", animations.durations.fast, ";", VisualElementButton, ":hover &{opacity:0.1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAyGqC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
84
|
+
})("background:black;opacity:0.05;position:absolute;top:0;left:0;bottom:0;right:0;border-radius:50%;transition:opacity ", animations.durations.fast, ";", VisualElementButton, ":hover &{opacity:0.1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAyGqC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
85
85
|
|
|
86
86
|
var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
87
87
|
name: "1s37602-TopicHeading",
|
|
@@ -89,7 +89,7 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
|
89
89
|
} : {
|
|
90
90
|
name: "1s37602-TopicHeading",
|
|
91
91
|
styles: "color:#fff;label:TopicHeading;",
|
|
92
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA2IO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
92
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA2IO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
93
93
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
94
94
|
};
|
|
95
95
|
|
|
@@ -102,7 +102,7 @@ var TopicHeading = /*#__PURE__*/_styled("h1", {
|
|
|
102
102
|
from: breakpoints.desktop
|
|
103
103
|
}), "{margin:50px 0 0;", fonts.sizes('38px', '48px'), ";}", function (props) {
|
|
104
104
|
return props.invertedStyle && _ref4;
|
|
105
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwH6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
105
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwH6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
106
106
|
|
|
107
107
|
var StyledHeadingText = /*#__PURE__*/_styled("span", {
|
|
108
108
|
target: "e111uita6",
|
|
@@ -113,19 +113,19 @@ var StyledHeadingText = /*#__PURE__*/_styled("span", {
|
|
|
113
113
|
} : {
|
|
114
114
|
name: "h6gn7j",
|
|
115
115
|
styles: "margin-right:28px",
|
|
116
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAgJqC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
116
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAgJqC","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
117
117
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
118
118
|
});
|
|
119
119
|
|
|
120
120
|
var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
|
|
121
121
|
target: "e111uita5",
|
|
122
122
|
label: "StyledAdditionalResourceMark"
|
|
123
|
-
})("text-align:center;display:inline-block;line-height:18px;width:20px;height:20px;border:1px solid ", colors.brand.dark, ";border-radius:100px;margin-right:7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAoJgD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
123
|
+
})("text-align:center;display:inline-block;line-height:18px;width:20px;height:20px;border:1px solid ", colors.brand.dark, ";border-radius:100px;margin-right:7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAoJgD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
124
124
|
|
|
125
125
|
var StyledAdditionalResource = /*#__PURE__*/_styled("span", {
|
|
126
126
|
target: "e111uita4",
|
|
127
127
|
label: "StyledAdditionalResource"
|
|
128
|
-
})("font-weight:", fonts.weight.semibold, ";", fonts.sizes('12px', '15px'), ";color:", colors.brand.dark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA8J4C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
128
|
+
})("font-weight:", fonts.weight.semibold, ";", fonts.sizes('12px', '15px'), ";color:", colors.brand.dark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA8J4C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
129
129
|
|
|
130
130
|
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
131
131
|
name: "9ayvfu-TopicIntroduction",
|
|
@@ -133,7 +133,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
|
133
133
|
} : {
|
|
134
134
|
name: "9ayvfu-TopicIntroduction",
|
|
135
135
|
styles: "color:#fff;label:TopicIntroduction;",
|
|
136
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA6KO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
136
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA6KO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
137
137
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
138
138
|
};
|
|
139
139
|
|
|
@@ -144,7 +144,7 @@ var TopicIntroduction = /*#__PURE__*/_styled("div", {
|
|
|
144
144
|
from: breakpoints.tablet
|
|
145
145
|
}), "{", fonts.sizes('22px', '32px'), ";}", function (props) {
|
|
146
146
|
return props.invertedStyle && _ref3;
|
|
147
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAoKmD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
147
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAoKmD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
148
148
|
|
|
149
149
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
150
150
|
name: "1pu3m2l-StyledButtonWrapper",
|
|
@@ -152,7 +152,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
152
152
|
} : {
|
|
153
153
|
name: "1pu3m2l-StyledButtonWrapper",
|
|
154
154
|
styles: "button{color:#fff;&:hover,&:focus{color:#fff;}};label:StyledButtonWrapper;",
|
|
155
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwLO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
155
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwLO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
156
156
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
157
157
|
};
|
|
158
158
|
|
|
@@ -161,7 +161,7 @@ var StyledButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
|
161
161
|
label: "StyledButtonWrapper"
|
|
162
162
|
})("margin-top:", spacing.small, ";padding:", spacing.xsmall, " 0 ", spacing.xsmall, " ", spacing.medium, ";border-left:6px solid ", colors.brand.light, ";", function (props) {
|
|
163
163
|
return props.invertedStyle && _ref2;
|
|
164
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAkLqD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
164
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAkLqD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
165
165
|
|
|
166
166
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
167
167
|
name: "62gb8t-StyledContentWrapper",
|
|
@@ -169,7 +169,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
169
169
|
} : {
|
|
170
170
|
name: "62gb8t-StyledContentWrapper",
|
|
171
171
|
styles: "background:#fff;label:StyledContentWrapper;",
|
|
172
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA0MO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
172
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA0MO","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
|
|
173
173
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
174
174
|
};
|
|
175
175
|
|
|
@@ -178,15 +178,16 @@ var StyledContentWrapper = /*#__PURE__*/_styled("div", {
|
|
|
178
178
|
label: "StyledContentWrapper"
|
|
179
179
|
})("padding-top:", spacing.normal, ";margin-top:0;border-left:6px solid ", colors.brand.light, ";", function (props) {
|
|
180
180
|
return props.invertedStyle && _ref;
|
|
181
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAmMsD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
181
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAmMsD","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
182
182
|
|
|
183
183
|
var StyledNavigationBoxWrapper = /*#__PURE__*/_styled("div", {
|
|
184
184
|
target: "e111uita0",
|
|
185
185
|
label: "StyledNavigationBoxWrapper"
|
|
186
|
-
})("padding-top:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+M6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
186
|
+
})("padding-top:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+M6C","file":"Topic.tsx","sourcesContent":["/**\n * Copyright (c) 2021-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode, MouseEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\nimport parse from 'html-react-parser';\nimport { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport Button from '@ndla/button';\nimport { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';\nimport { css } from '@emotion/react';\nimport { useTranslation } from 'react-i18next';\nimport Loader from './Loader';\nimport { ItemProps } from '../Navigation/NavigationBox';\nimport { NavigationBox } from '../Navigation';\nimport { makeSrcQueryString, ImageCrop, ImageFocalPoint } from '../Image';\nimport { MessageBox } from '../Messages';\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\ntype FrameProps = {\n  frame?: boolean;\n};\n\nconst Wrapper = styled.section<FrameProps>`\n  ${(props) =>\n    props.frame &&\n    css`\n      ${mq.range({ from: breakpoints.tabletWide })} {\n        padding: 40px 40px;\n        border: 2px solid #d1d6db;\n      }\n      ${mq.range({ from: breakpoints.desktop })} {\n        padding: 40px 80px;\n      }\n      ${mq.range({ from: '1180px' })} {\n        padding: 60px 160px;\n      }\n    `}\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\n  float: right;\n  margin-left: ${spacing.normal};\n  position: relative;\n  width: 100px;\n  height: 100px;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 150px;\n    height: 150px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 200px;\n    height: 200px;\n  }\n`;\n\nconst ShowVisualElementWrapper = styled.div`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(Button)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n  transition: transform ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    transform: scale(1.1);\n    opacity: 1.2;\n  }\n`;\n\nconst ExpandVisualElementButton = styled.span`\n  position: absolute;\n  right: -10px;\n  bottom: -4px;\n  transition: all ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    right: 10px;\n  }\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    right: 0;\n    bottom: 0;\n  }\n`;\n\nconst TopicHeaderOverlay = styled.div`\n  background: black;\n  opacity: 0.05;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  border-radius: 50%;\n  transition: opacity ${animations.durations.fast};\n  ${VisualElementButton}:hover & {\n    opacity: 0.1;\n  }\n`;\n\nconst TopicHeading = styled.h1<InvertItProps>`\n  margin: ${spacing.medium} 0 0;\n  font-weight: ${fonts.weight.bold};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  ${fonts.sizes('24px', '28px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('32px', '28px')};\n    margin: 40px 0 0;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: 50px 0 0;\n    ${fonts.sizes('38px', '48px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledHeadingText = styled.span`\n  margin-right: 28px;\n`;\n\nconst StyledAdditionalResourceMark = styled.span`\n  text-align: center;\n  display: inline-block;\n  line-height: 18px;\n  width: 20px;\n  height: 20px;\n  border: 1px solid ${colors.brand.dark};\n  border-radius: 100px;\n  margin-right: 7px;\n`;\nconst StyledAdditionalResource = styled.span`\n  font-weight: ${fonts.weight.semibold};\n  ${fonts.sizes('12px', '15px')};\n  color: ${colors.brand.dark};\n`;\n\nconst TopicIntroduction = styled.div<InvertItProps>`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  margin-top: ${spacing.xsmall};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\n  }\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      color: #fff;\n    `}\n`;\n\nconst StyledButtonWrapper = styled.div<InvertItProps>`\n  margin-top: ${spacing.small};\n  padding: ${spacing.xsmall} 0 ${spacing.xsmall} ${spacing.medium};\n  border-left: 6px solid ${colors.brand.light};\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      button {\n        color: #fff;\n        &:hover,\n        &:focus {\n          color: #fff;\n        }\n      }\n    `}\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  margin-top: 0;\n  border-left: 6px solid ${colors.brand.light};\n\n  ${(props) =>\n    props.invertedStyle &&\n    css`\n      background: #fff;\n    `}\n`;\n\nconst StyledNavigationBoxWrapper = styled.div`\n  padding-top: ${spacing.xxsmall};\n`;\n\ntype VisualElementProps = {\n  type: 'image' | 'video' | 'other';\n  element: ReactNode;\n};\n\nexport type TopicProps = {\n  id?: string;\n  topic?: {\n    title: string;\n    introduction: string;\n    image?: {\n      url: string;\n      alt: string;\n      crop?: ImageCrop;\n      focalPoint?: ImageFocalPoint;\n    };\n    visualElement?: VisualElementProps;\n    resources?: ReactNode;\n  };\n  subTopics?: ItemProps[] | null | undefined;\n  onSubTopicSelected?: (event: MouseEvent<HTMLElement>, id?: string) => void;\n  isLoading?: boolean;\n  renderMarkdown?: (text: string) => string;\n  invertedStyle?: boolean;\n  onToggleShowContent?: () => void;\n  showContent?: boolean;\n  isAdditionalTopic?: boolean;\n  frame?: boolean;\n  messageBox?: string;\n  children?: ReactNode;\n};\n\nconst Topic = ({\n  id,\n  topic,\n  subTopics,\n  onSubTopicSelected,\n  isLoading,\n  renderMarkdown,\n  invertedStyle,\n  onToggleShowContent,\n  showContent,\n  isAdditionalTopic,\n  frame,\n  messageBox,\n  children,\n}: TopicProps) => {\n  const { t } = useTranslation();\n  return (\n    <Wrapper frame={frame} data-testid=\"nav-topic-about\">\n      {isLoading ? (\n        <Loader />\n      ) : (\n        <>\n          {topic && (\n            <>\n              {topic.image && (\n                <TopicHeaderVisualElementWrapper>\n                  {topic.visualElement ? (\n                    <>\n                      <Modal\n                        label={t('topicPage.imageModal')}\n                        activateButton={\n                          <VisualElementButton\n                            stripped\n                            title={\n                              topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')\n                            }>\n                            <ShowVisualElementWrapper>\n                              <TopicHeaderImage\n                                src={`${topic.image.url}?${makeSrcQueryString(\n                                  800,\n                                  topic.image.crop,\n                                  topic.image.focalPoint,\n                                )}`}\n                                alt={topic.image.alt}\n                              />\n                              <TopicHeaderOverlay />\n                            </ShowVisualElementWrapper>\n                            <ExpandVisualElementButton>\n                              {topic.visualElement.type === 'image' && (\n                                <ExpandTwoArrows style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'video' && (\n                                <PlayCircleFilled style={{ width: '24px', height: '24px' }} />\n                              )}\n                              {topic.visualElement.type === 'other' && (\n                                <CursorClick style={{ width: '24px', height: '24px' }} />\n                              )}\n                            </ExpandVisualElementButton>\n                          </VisualElementButton>\n                        }\n                        animation=\"subtle\"\n                        animationDuration={50}\n                        backgroundColor=\"white\"\n                        size=\"large\">\n                        {(onClose: () => void) => (\n                          <>\n                            <ModalHeader>\n                              <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                            </ModalHeader>\n                            <ModalBody modifier=\"no-side-padding-mobile\">\n                              {topic.visualElement && topic.visualElement.element}\n                            </ModalBody>\n                          </>\n                        )}\n                      </Modal>\n                    </>\n                  ) : (\n                    <TopicHeaderImage\n                      src={`${topic.image.url}?${makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)}`}\n                      alt={topic.image.alt}\n                    />\n                  )}\n                </TopicHeaderVisualElementWrapper>\n              )}\n              <TopicHeading invertedStyle={invertedStyle} id={id} tabIndex={-1}>\n                <StyledHeadingText>{topic.title}</StyledHeadingText>\n                {isAdditionalTopic && (\n                  <StyledAdditionalResource>\n                    <StyledAdditionalResourceMark>T</StyledAdditionalResourceMark>\n                    {t('navigation.additionalTopic')}\n                  </StyledAdditionalResource>\n                )}\n              </TopicHeading>\n              {messageBox && <MessageBox>{messageBox}</MessageBox>}\n              <TopicIntroduction invertedStyle={invertedStyle}>\n                {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n              </TopicIntroduction>\n              {onToggleShowContent && (\n                <StyledButtonWrapper invertedStyle={invertedStyle}>\n                  <Button\n                    aria-expanded={!!showContent}\n                    link\n                    onClick={() => {\n                      onToggleShowContent();\n                    }}>\n                    {showContent ? (\n                      <>\n                        {t('navigation.showShorterDescription')} <ChevronUp />\n                      </>\n                    ) : (\n                      <>\n                        {t('navigation.showLongerDescription')} <ChevronDown />\n                      </>\n                    )}\n                  </Button>\n                </StyledButtonWrapper>\n              )}\n              {showContent && <StyledContentWrapper invertedStyle={invertedStyle}>{children}</StyledContentWrapper>}\n              {subTopics && subTopics.length !== 0 && (\n                <StyledNavigationBoxWrapper>\n                  <NavigationBox\n                    colorMode=\"light\"\n                    heading={t('navigation.topics')}\n                    items={subTopics}\n                    onClick={onSubTopicSelected}\n                    invertedStyle={invertedStyle}\n                  />\n                </StyledNavigationBoxWrapper>\n              )}\n              {topic.resources}\n            </>\n          )}\n        </>\n      )}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
|
|
187
187
|
|
|
188
188
|
var Topic = function Topic(_ref5) {
|
|
189
|
-
var
|
|
189
|
+
var id = _ref5.id,
|
|
190
|
+
topic = _ref5.topic,
|
|
190
191
|
subTopics = _ref5.subTopics,
|
|
191
192
|
onSubTopicSelected = _ref5.onSubTopicSelected,
|
|
192
193
|
isLoading = _ref5.isLoading,
|
|
@@ -262,6 +263,8 @@ var Topic = function Topic(_ref5) {
|
|
|
262
263
|
})
|
|
263
264
|
}), _jsxs(TopicHeading, {
|
|
264
265
|
invertedStyle: invertedStyle,
|
|
266
|
+
id: id,
|
|
267
|
+
tabIndex: -1,
|
|
265
268
|
children: [_jsx(StyledHeadingText, {
|
|
266
269
|
children: topic.title
|
|
267
270
|
}), isAdditionalTopic && _jsxs(StyledAdditionalResource, {
|