@ndla/ui 34.0.0 → 34.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/es/Figure/Figure.js +3 -2
  2. package/es/FileList/File.js +6 -6
  3. package/es/LanguageSelector/LanguageSelector.js +67 -99
  4. package/es/NDLAFilm/AboutNdlaFilm.js +13 -12
  5. package/es/NDLAFilm/AllMoviesAlphabetically.js +79 -144
  6. package/es/NDLAFilm/FilmContentCard.js +41 -26
  7. package/es/NDLAFilm/FilmContentCardTags.js +5 -3
  8. package/es/NDLAFilm/FilmMovieList.js +13 -8
  9. package/es/NDLAFilm/FilmMovieSearch.js +6 -5
  10. package/es/NDLAFilm/FilmSlideshow.js +44 -20
  11. package/es/NDLAFilm/filmStyles.js +2 -2
  12. package/es/ResourceGroup/ResourceItem.js +72 -48
  13. package/es/ResourceGroup/ResourceList.js +4 -3
  14. package/es/Search/ActiveFilterContent.js +6 -5
  15. package/es/Search/ContentTypeResult.js +6 -3
  16. package/es/SearchTypeResult/ActiveFilterContent.js +9 -10
  17. package/es/Topic/Topic.js +171 -213
  18. package/es/all.css +1 -1
  19. package/es/locale/messages-en.js +3 -1
  20. package/es/locale/messages-nb.js +3 -1
  21. package/es/locale/messages-nn.js +7 -5
  22. package/es/locale/messages-se.js +2 -0
  23. package/es/locale/messages-sma.js +3 -1
  24. package/lib/Figure/Figure.d.ts +2 -1
  25. package/lib/Figure/Figure.js +3 -2
  26. package/lib/FileList/File.js +6 -6
  27. package/lib/LanguageSelector/LanguageSelector.d.ts +6 -15
  28. package/lib/LanguageSelector/LanguageSelector.js +64 -99
  29. package/lib/NDLAFilm/AboutNdlaFilm.js +11 -14
  30. package/lib/NDLAFilm/AllMoviesAlphabetically.d.ts +1 -2
  31. package/lib/NDLAFilm/AllMoviesAlphabetically.js +77 -142
  32. package/lib/NDLAFilm/FilmContentCard.d.ts +7 -0
  33. package/lib/NDLAFilm/FilmContentCard.js +41 -26
  34. package/lib/NDLAFilm/FilmContentCardTags.d.ts +2 -1
  35. package/lib/NDLAFilm/FilmContentCardTags.js +5 -3
  36. package/lib/NDLAFilm/FilmMovieList.js +12 -7
  37. package/lib/NDLAFilm/FilmMovieSearch.js +5 -4
  38. package/lib/NDLAFilm/FilmSlideshow.js +44 -20
  39. package/lib/NDLAFilm/filmStyles.js +2 -2
  40. package/lib/Resource/resourceComponents.d.ts +1 -1
  41. package/lib/ResourceGroup/ResourceItem.d.ts +2 -2
  42. package/lib/ResourceGroup/ResourceItem.js +72 -48
  43. package/lib/ResourceGroup/ResourceList.js +4 -3
  44. package/lib/Search/ActiveFilterContent.d.ts +1 -1
  45. package/lib/Search/ActiveFilterContent.js +9 -5
  46. package/lib/Search/ContentTypeResult.js +6 -3
  47. package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
  48. package/lib/SearchTypeResult/ActiveFilterContent.js +12 -10
  49. package/lib/Topic/Topic.js +170 -215
  50. package/lib/all.css +1 -1
  51. package/lib/locale/messages-en.d.ts +2 -0
  52. package/lib/locale/messages-en.js +3 -1
  53. package/lib/locale/messages-nb.d.ts +2 -0
  54. package/lib/locale/messages-nb.js +3 -1
  55. package/lib/locale/messages-nn.d.ts +4 -2
  56. package/lib/locale/messages-nn.js +7 -5
  57. package/lib/locale/messages-se.d.ts +2 -0
  58. package/lib/locale/messages-se.js +2 -0
  59. package/lib/locale/messages-sma.d.ts +2 -0
  60. package/lib/locale/messages-sma.js +3 -1
  61. package/package.json +15 -14
  62. package/src/Figure/Figure.tsx +6 -2
  63. package/src/FileList/File.tsx +4 -4
  64. package/src/LanguageSelector/LanguageSelector.stories.tsx +48 -0
  65. package/src/LanguageSelector/LanguageSelector.tsx +70 -149
  66. package/src/NDLAFilm/AboutNdlaFilm.tsx +11 -14
  67. package/src/NDLAFilm/AllMoviesAlphabetically.tsx +44 -160
  68. package/src/NDLAFilm/FilmContentCard.tsx +40 -21
  69. package/src/NDLAFilm/FilmContentCardTags.tsx +3 -2
  70. package/src/NDLAFilm/FilmMovieList.tsx +14 -7
  71. package/src/NDLAFilm/FilmMovieSearch.tsx +2 -2
  72. package/src/NDLAFilm/FilmSlideshow.tsx +49 -40
  73. package/src/NDLAFilm/filmStyles.ts +1 -1
  74. package/src/ResourceGroup/ResourceItem.tsx +79 -94
  75. package/src/ResourceGroup/ResourceList.tsx +2 -0
  76. package/src/Search/ActiveFilterContent.tsx +4 -3
  77. package/src/Search/ContentTypeResult.tsx +3 -1
  78. package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -8
  79. package/src/Topic/Topic.tsx +166 -193
  80. package/src/locale/messages-en.ts +3 -1
  81. package/src/locale/messages-nb.ts +3 -1
  82. package/src/locale/messages-nn.ts +5 -4
  83. package/src/locale/messages-se.ts +2 -0
  84. package/src/locale/messages-sma.ts +3 -1
  85. package/src/main.scss +0 -1
  86. package/es/LanguageSelector/LanguageSelectorContent.js +0 -61
  87. package/es/Subject/SubjectCarousel.js +0 -133
  88. package/lib/LanguageSelector/LanguageSelectorContent.d.ts +0 -15
  89. package/lib/LanguageSelector/LanguageSelectorContent.js +0 -68
  90. package/lib/Subject/SubjectCarousel.d.ts +0 -18
  91. package/lib/Subject/SubjectCarousel.js +0 -138
  92. package/src/LanguageSelector/LanguageSelectorContent.tsx +0 -80
  93. package/src/NDLAFilm/component.film-movielist.scss +0 -105
  94. package/src/Subject/SubjectCarousel.tsx +0 -162
package/es/Topic/Topic.js CHANGED
@@ -12,8 +12,8 @@ import React from 'react';
12
12
  import { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
13
13
  import parse from 'html-react-parser';
14
14
  import { ChevronDown, ChevronUp, PlayCircleFilled } from '@ndla/icons/common';
15
- import Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';
16
- import Button from '@ndla/button';
15
+ import { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';
16
+ import { ButtonV2 } from '@ndla/button';
17
17
  import { CursorClick, ExpandTwoArrows } from '@ndla/icons/action';
18
18
  import { css } from '@emotion/react';
19
19
  import { useTranslation } from 'react-i18next';
@@ -22,266 +22,224 @@ import { NavigationBox } from '../Navigation';
22
22
  import { makeSrcQueryString } from '../Image';
23
23
  import { MessageBox } from '../Messages';
24
24
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
25
- import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
26
25
  import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
27
- var Wrapper = /*#__PURE__*/_styled("section", {
28
- target: "e111uita14",
26
+ import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
27
+ var Wrapper = /*#__PURE__*/_styled("div", {
28
+ target: "e111uita13",
29
29
  label: "Wrapper"
30
- })(function (props) {
31
- return props.frame && /*#__PURE__*/css(mq.range({
32
- from: breakpoints.tabletWide
33
- }), "{padding:40px 40px;border:2px solid #d1d6db;}", mq.range({
34
- from: breakpoints.desktop
35
- }), "{padding:40px 80px;}", mq.range({
36
- from: '1180px'
37
- }), "{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"]} */"));
38
- }, ";" + (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"]} */"));
30
+ })("display:flex;flex-direction:column;gap:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA6B0B","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
31
+ var frameStyle = /*#__PURE__*/css(mq.range({
32
+ from: breakpoints.tabletWide
33
+ }), "{padding:40px 40px;border:2px solid ", colors.brand.neutral7, ";}", mq.range({
34
+ from: breakpoints.desktop
35
+ }), "{padding:40px 80px;}", mq.range({
36
+ from: '1180px'
37
+ }), "{padding:60px 160px;};label:frameStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAmCsB","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
38
+ var _invertedStyle = /*#__PURE__*/css("color:", colors.white, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAgD0B","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
39
39
  var TopicHeaderVisualElementWrapper = /*#__PURE__*/_styled("div", {
40
- target: "e111uita13",
40
+ target: "e111uita12",
41
41
  label: "TopicHeaderVisualElementWrapper"
42
- })("float:right;margin-left:", spacing.normal, ";position:relative;width:100px;height:100px;", mq.range({
42
+ })("position:relative;width:100px;height:100px;", mq.range({
43
43
  from: breakpoints.mobileWide
44
44
  }), "{width:150px;height:150px;}", mq.range({
45
- from: breakpoints.tablet
46
- }), "{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"]} */"));
45
+ from: breakpoints.tabletWide
46
+ }), "{width:200px;height:200px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAoDkD","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
47
47
  var ShowVisualElementWrapper = /*#__PURE__*/_styled("div", {
48
- target: "e111uita12",
48
+ target: "e111uita11",
49
49
  label: "ShowVisualElementWrapper"
50
50
  })(process.env.NODE_ENV === "production" ? {
51
- name: "123g6v6",
52
- styles: "border-radius:50%;width:100%;height:100%;overflow:hidden;-webkit-mask-image:-webkit-radial-gradient(white, black)"
51
+ name: "1v6dfx3",
52
+ styles: "border-radius:50%;width:100%;height:100%;overflow:hidden;aspect-ratio:1;-webkit-mask-image:-webkit-radial-gradient(white, black)"
53
53
  } : {
54
- name: "123g6v6",
55
- styles: "border-radius:50%;width:100%;height:100%;overflow:hidden;-webkit-mask-image:-webkit-radial-gradient(white, black)",
56
- 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"]} */",
54
+ name: "1v6dfx3",
55
+ styles: "border-radius:50%;width:100%;height:100%;overflow:hidden;aspect-ratio:1;-webkit-mask-image:-webkit-radial-gradient(white, black)",
56
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAkE2C","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
57
57
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
58
58
  });
59
- var VisualElementButton = /*#__PURE__*/_styled(Button, {
60
- target: "e111uita11",
59
+ var VisualElementButton = /*#__PURE__*/_styled(ButtonV2, {
60
+ target: "e111uita10",
61
61
  label: "VisualElementButton"
62
- })("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"]} */"));
62
+ })("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":"AA2E4C","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
63
63
  var TopicHeaderImage = /*#__PURE__*/_styled("img", {
64
- target: "e111uita10",
64
+ target: "e111uita9",
65
65
  label: "TopicHeaderImage"
66
- })("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"]} */"));
66
+ })("border-radius:50%;aspect-ratio:1;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":"AAiFmC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
67
67
  var ExpandVisualElementButton = /*#__PURE__*/_styled("span", {
68
- target: "e111uita9",
68
+ target: "e111uita8",
69
69
  label: "ExpandVisualElementButton"
70
- })("position:absolute;right:-10px;bottom:-4px;transition:all ", animations.durations.fast, ";", VisualElementButton, ":hover &{right:10px;}", mq.range({
70
+ })("position:absolute;right:-10px;bottom:-4px;transition:all ", animations.durations.fast, ";svg{width:24px;height:24px;}", VisualElementButton, ":hover &{right:10px;}", mq.range({
71
71
  from: breakpoints.mobileWide
72
- }), "{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"]} */"));
72
+ }), "{right:0;bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA8F6C","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
73
73
  var TopicHeaderOverlay = /*#__PURE__*/_styled("div", {
74
- target: "e111uita8",
75
- label: "TopicHeaderOverlay"
76
- })("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"]} */"));
77
- var _ref4 = process.env.NODE_ENV === "production" ? {
78
- name: "1s37602-TopicHeading",
79
- styles: "color:#fff;label:TopicHeading;"
80
- } : {
81
- name: "1s37602-TopicHeading",
82
- styles: "color:#fff;label:TopicHeading;",
83
- 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"]} */",
84
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
- };
86
- var TopicHeading = /*#__PURE__*/_styled("h1", {
87
74
  target: "e111uita7",
88
- label: "TopicHeading"
89
- })("margin:", spacing.medium, " 0 0;font-weight:", fonts.weight.bold, ";display:flex;flex-wrap:wrap;align-items:center;", fonts.sizes('24px', '28px'), ";", mq.range({
90
- from: breakpoints.tablet
91
- }), "{", fonts.sizes('32px', '28px'), ";margin:40px 0 0;}", mq.range({
92
- from: breakpoints.desktop
93
- }), "{margin:50px 0 0;", fonts.sizes('38px', '48px'), ";}", function (props) {
94
- return props.invertedStyle && _ref4;
95
- }, ";" + (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"]} */"));
96
- var StyledHeadingText = /*#__PURE__*/_styled("span", {
75
+ label: "TopicHeaderOverlay"
76
+ })("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":"AAgHqC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
77
+ var TopicIntroductionWrapper = /*#__PURE__*/_styled("div", {
97
78
  target: "e111uita6",
98
- label: "StyledHeadingText"
99
- })(process.env.NODE_ENV === "production" ? {
100
- name: "h6gn7j",
101
- styles: "margin-right:28px"
102
- } : {
103
- name: "h6gn7j",
104
- styles: "margin-right:28px",
105
- 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"]} */",
106
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
- });
108
- var StyledAdditionalResourceMark = /*#__PURE__*/_styled("span", {
79
+ label: "TopicIntroductionWrapper"
80
+ })("display:flex;gap:", spacing.xsmall, ";justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+H2C","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
81
+ var HeadingWrapper = /*#__PURE__*/_styled("hgroup", {
109
82
  target: "e111uita5",
110
- label: "StyledAdditionalResourceMark"
111
- })("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"]} */"));
112
- var StyledAdditionalResource = /*#__PURE__*/_styled("span", {
113
- target: "e111uita4",
114
- label: "StyledAdditionalResource"
115
- })("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"]} */"));
116
- var _ref3 = process.env.NODE_ENV === "production" ? {
117
- name: "9ayvfu-TopicIntroduction",
118
- styles: "color:#fff;label:TopicIntroduction;"
119
- } : {
120
- name: "9ayvfu-TopicIntroduction",
121
- styles: "color:#fff;label:TopicIntroduction;",
122
- 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"]} */",
123
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
124
- };
83
+ label: "HeadingWrapper"
84
+ })("display:flex;flex-wrap:wrap;align-items:center;gap:", spacing.small, ";h1{margin:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAqIoC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
125
85
  var TopicIntroduction = /*#__PURE__*/_styled("div", {
126
- target: "e111uita3",
86
+ target: "e111uita4",
127
87
  label: "TopicIntroduction"
128
- })("font-weight:", fonts.weight.light, ";max-width:612px;margin-top:", spacing.xsmall, ";", mq.range({
88
+ })("font-weight:", fonts.weight.light, ";max-width:612px;", mq.range({
129
89
  from: breakpoints.tablet
130
- }), "{", fonts.sizes('22px', '32px'), ";}", function (props) {
131
- return props.invertedStyle && _ref3;
132
- }, ";" + (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"]} */"));
133
- var _ref2 = process.env.NODE_ENV === "production" ? {
90
+ }), "{", fonts.sizes('22px', '32px'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA+IoC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
91
+ var _ref = process.env.NODE_ENV === "production" ? {
134
92
  name: "1pu3m2l-StyledButtonWrapper",
135
93
  styles: "button{color:#fff;&:hover,&:focus{color:#fff;}};label:StyledButtonWrapper;"
136
94
  } : {
137
95
  name: "1pu3m2l-StyledButtonWrapper",
138
96
  styles: "button{color:#fff;&:hover,&:focus{color:#fff;}};label:StyledButtonWrapper;",
139
- 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"]} */",
97
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AA6JO","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
140
98
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
141
99
  };
142
100
  var StyledButtonWrapper = /*#__PURE__*/_styled("div", {
143
- target: "e111uita2",
101
+ target: "e111uita3",
144
102
  label: "StyledButtonWrapper"
145
103
  })("margin-top:", spacing.small, ";padding:", spacing.xsmall, " 0 ", spacing.xsmall, " ", spacing.medium, ";border-left:6px solid ", colors.brand.light, ";", function (props) {
146
- return props.invertedStyle && _ref2;
147
- }, ";" + (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"]} */"));
148
- var _ref = process.env.NODE_ENV === "production" ? {
149
- name: "62gb8t-StyledContentWrapper",
150
- styles: "background:#fff;label:StyledContentWrapper;"
104
+ return props.invertedStyle && _ref;
105
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAuJqD","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
106
+ var AdditionalIcon = /*#__PURE__*/_styled("span", {
107
+ target: "e111uita2",
108
+ label: "AdditionalIcon"
109
+ })(process.env.NODE_ENV === "production" ? {
110
+ name: "1qitjsl",
111
+ styles: "padding:1px;border:1px solid currentColor;border-radius:100%;font-size:15px;width:25px;text-align:center"
151
112
  } : {
152
- name: "62gb8t-StyledContentWrapper",
153
- styles: "background:#fff;label:StyledContentWrapper;",
154
- 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"]} */",
113
+ name: "1qitjsl",
114
+ styles: "padding:1px;border:1px solid currentColor;border-radius:100%;font-size:15px;width:25px;text-align:center",
115
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwKkC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */",
155
116
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
156
- };
117
+ });
157
118
  var StyledContentWrapper = /*#__PURE__*/_styled("div", {
158
119
  target: "e111uita1",
159
120
  label: "StyledContentWrapper"
160
- })("padding-top:", spacing.normal, ";margin-top:0;border-left:6px solid ", colors.brand.light, ";", function (props) {
161
- return props.invertedStyle && _ref;
162
- }, ";" + (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"]} */"));
163
- var StyledNavigationBoxWrapper = /*#__PURE__*/_styled("div", {
121
+ })("padding-top:", spacing.normal, ";border-left:6px solid ", colors.brand.light, ";color:", colors.text.primary, ";background-color:", colors.white, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAiLsD","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
122
+ var ModalHeader = /*#__PURE__*/_styled(ModalHeaderV2, {
164
123
  target: "e111uita0",
165
- label: "StyledNavigationBoxWrapper"
166
- })("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"]} */"));
167
- var Topic = function Topic(_ref5) {
168
- var id = _ref5.id,
169
- topic = _ref5.topic,
170
- subTopics = _ref5.subTopics,
171
- onSubTopicSelected = _ref5.onSubTopicSelected,
172
- isLoading = _ref5.isLoading,
173
- renderMarkdown = _ref5.renderMarkdown,
174
- invertedStyle = _ref5.invertedStyle,
175
- onToggleShowContent = _ref5.onToggleShowContent,
176
- showContent = _ref5.showContent,
177
- isAdditionalTopic = _ref5.isAdditionalTopic,
178
- frame = _ref5.frame,
179
- messageBox = _ref5.messageBox,
180
- children = _ref5.children;
124
+ label: "ModalHeader"
125
+ })("padding:", spacing.small, " ", spacing.nsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Topic.tsx"],"names":[],"mappings":"AAwLyC","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, ComponentType } 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 { ModalCloseButton, ModalV2, ModalHeaderV2 } from '@ndla/modal';\nimport { ButtonV2 } 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};\n\nconst Wrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: ${spacing.small};\n`;\n\nconst frameStyle = css`\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding: 40px 40px;\n    border: 2px solid ${colors.brand.neutral7};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 40px 80px;\n  }\n  ${mq.range({ from: '1180px' })} {\n    padding: 60px 160px;\n  }\n`;\n\nconst _invertedStyle = css`\n  color: ${colors.white};\n`;\n\nconst TopicHeaderVisualElementWrapper = styled.div`\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.tabletWide })} {\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  aspect-ratio: 1;\n  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari fix */\n`;\n\nconst VisualElementButton = styled(ButtonV2)`\n  color: ${colors.brand.secondary};\n  width: 100%;\n  height: 100%;\n`;\n\nconst TopicHeaderImage = styled.img`\n  border-radius: 50%;\n  aspect-ratio: 1;\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  svg {\n    width: 24px;\n    height: 24px;\n  }\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 TopicIntroductionWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  justify-content: space-between;\n`;\n\nconst HeadingWrapper = styled.hgroup`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${spacing.small};\n  h1 {\n    margin: 0;\n  }\n`;\n\nconst TopicIntroduction = styled.div`\n  font-weight: ${fonts.weight.light};\n  max-width: 612px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('22px', '32px')};\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 AdditionalIcon = styled.span`\n  padding: 1px;\n  border: 1px solid currentColor;\n  border-radius: 100%;\n  font-size: 15px;\n  width: 25px;\n  text-align: center;\n`;\n\nconst StyledContentWrapper = styled.div<InvertItProps>`\n  padding-top: ${spacing.normal};\n  border-left: 6px solid ${colors.brand.light};\n  color: ${colors.text.primary};\n  background-color: ${colors.white};\n`;\n\nconst ModalHeader = styled(ModalHeaderV2)`\n  padding: ${spacing.small} ${spacing.nsmall};\n`;\n\nconst icons: Record<VisualElementProps['type'], ComponentType> = {\n  image: ExpandTwoArrows,\n  video: PlayCircleFilled,\n  other: CursorClick,\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  const contentId = `expanded-description-${id}`;\n  const testId = 'nav-topic-about';\n  const VisualElementIcon = topic?.visualElement?.type ? icons[topic.visualElement.type] : null;\n  const wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];\n  if (isLoading || !topic) {\n    return (\n      <Wrapper css={wrapperStyle} data-testid={testId}>\n        {isLoading ? <Loader /> : null}\n      </Wrapper>\n    );\n  }\n\n  return (\n    <Wrapper css={wrapperStyle} data-testid={testId}>\n      <TopicIntroductionWrapper>\n        <div>\n          <HeadingWrapper>\n            <h1 id={id} tabIndex={-1}>\n              {topic.title}\n            </h1>\n            {isAdditionalTopic && (\n              <>\n                <AdditionalIcon aria-hidden=\"true\">T</AdditionalIcon>\n                <span>{t('navigation.additionalTopic')}</span>\n              </>\n            )}\n          </HeadingWrapper>\n          <TopicIntroduction>\n            {renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction}\n          </TopicIntroduction>\n        </div>\n        {topic.image && (\n          <TopicHeaderVisualElementWrapper>\n            {topic.visualElement ? (\n              <ModalV2\n                label={t('topicPage.imageModal')}\n                activateButton={\n                  <VisualElementButton\n                    variant=\"stripped\"\n                    title={topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show')}>\n                    <ShowVisualElementWrapper>\n                      <TopicHeaderImage\n                        src={`${topic.image.url}?${makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)}`}\n                        alt={topic.image.alt}\n                      />\n                      <TopicHeaderOverlay />\n                    </ShowVisualElementWrapper>\n                    <ExpandVisualElementButton>{VisualElementIcon && <VisualElementIcon />}</ExpandVisualElementButton>\n                  </VisualElementButton>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                size=\"large\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalCloseButton onClick={onClose} title={t('modal.closeModal')} />\n                    </ModalHeader>\n                    {topic.visualElement && topic.visualElement.element}\n                  </>\n                )}\n              </ModalV2>\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      </TopicIntroductionWrapper>\n      {messageBox && <MessageBox>{messageBox}</MessageBox>}\n      <div>\n        {onToggleShowContent && (\n          <StyledButtonWrapper invertedStyle={invertedStyle}>\n            <ButtonV2\n              aria-expanded={!!showContent}\n              aria-controls={contentId}\n              variant=\"link\"\n              onClick={() => onToggleShowContent()}>\n              {showContent ? (\n                <>\n                  {t('navigation.showShorterDescription')} <ChevronUp />\n                </>\n              ) : (\n                <>\n                  {t('navigation.showLongerDescription')} <ChevronDown />\n                </>\n              )}\n            </ButtonV2>\n          </StyledButtonWrapper>\n        )}\n        {showContent && (\n          <StyledContentWrapper id={contentId} invertedStyle={invertedStyle}>\n            {children}\n          </StyledContentWrapper>\n        )}\n      </div>\n      {subTopics && subTopics.length !== 0 && (\n        <NavigationBox\n          colorMode=\"light\"\n          heading={t('navigation.topics')}\n          items={subTopics}\n          onClick={onSubTopicSelected}\n          invertedStyle={invertedStyle}\n        />\n      )}\n      {topic.resources}\n    </Wrapper>\n  );\n};\nexport default Topic;\n"]} */"));
126
+ var icons = {
127
+ image: ExpandTwoArrows,
128
+ video: PlayCircleFilled,
129
+ other: CursorClick
130
+ };
131
+ var Topic = function Topic(_ref2) {
132
+ var _topic$visualElement;
133
+ var id = _ref2.id,
134
+ topic = _ref2.topic,
135
+ subTopics = _ref2.subTopics,
136
+ onSubTopicSelected = _ref2.onSubTopicSelected,
137
+ isLoading = _ref2.isLoading,
138
+ renderMarkdown = _ref2.renderMarkdown,
139
+ invertedStyle = _ref2.invertedStyle,
140
+ onToggleShowContent = _ref2.onToggleShowContent,
141
+ showContent = _ref2.showContent,
142
+ isAdditionalTopic = _ref2.isAdditionalTopic,
143
+ frame = _ref2.frame,
144
+ messageBox = _ref2.messageBox,
145
+ children = _ref2.children;
181
146
  var _useTranslation = useTranslation(),
182
147
  t = _useTranslation.t;
183
- return _jsx(Wrapper, {
184
- frame: frame,
185
- "data-testid": "nav-topic-about",
186
- children: isLoading ? _jsx(Loader, {}) : _jsx(_Fragment, {
187
- children: topic && _jsxs(_Fragment, {
188
- children: [topic.image && _jsx(TopicHeaderVisualElementWrapper, {
189
- children: topic.visualElement ? _jsx(_Fragment, {
190
- children: _jsx(Modal, {
191
- label: t('topicPage.imageModal'),
192
- activateButton: _jsxs(VisualElementButton, {
193
- stripped: true,
194
- title: topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show'),
195
- children: [_jsxs(ShowVisualElementWrapper, {
196
- children: [_jsx(TopicHeaderImage, {
197
- src: "".concat(topic.image.url, "?").concat(makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)),
198
- alt: topic.image.alt
199
- }), _jsx(TopicHeaderOverlay, {})]
200
- }), _jsxs(ExpandVisualElementButton, {
201
- children: [topic.visualElement.type === 'image' && _jsx(ExpandTwoArrows, {
202
- style: {
203
- width: '24px',
204
- height: '24px'
205
- }
206
- }), topic.visualElement.type === 'video' && _jsx(PlayCircleFilled, {
207
- style: {
208
- width: '24px',
209
- height: '24px'
210
- }
211
- }), topic.visualElement.type === 'other' && _jsx(CursorClick, {
212
- style: {
213
- width: '24px',
214
- height: '24px'
215
- }
216
- })]
217
- })]
218
- }),
219
- animation: "subtle",
220
- animationDuration: 50,
221
- backgroundColor: "white",
222
- size: "large",
223
- children: function children(onClose) {
224
- return _jsxs(_Fragment, {
225
- children: [_jsx(ModalHeader, {
226
- children: _jsx(ModalCloseButton, {
227
- onClick: onClose,
228
- title: t('modal.closeModal')
229
- })
230
- }), _jsx(ModalBody, {
231
- modifier: "no-side-padding-mobile",
232
- children: topic.visualElement && topic.visualElement.element
233
- })]
234
- });
235
- }
236
- })
237
- }) : _jsx(TopicHeaderImage, {
238
- src: "".concat(topic.image.url, "?").concat(makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)),
239
- alt: topic.image.alt
240
- })
241
- }), _jsxs(TopicHeading, {
242
- invertedStyle: invertedStyle,
243
- id: id,
244
- tabIndex: -1,
245
- children: [_jsx(StyledHeadingText, {
148
+ var contentId = "expanded-description-".concat(id);
149
+ var testId = 'nav-topic-about';
150
+ var VisualElementIcon = topic !== null && topic !== void 0 && (_topic$visualElement = topic.visualElement) !== null && _topic$visualElement !== void 0 && _topic$visualElement.type ? icons[topic.visualElement.type] : null;
151
+ var wrapperStyle = [frame ? frameStyle : undefined, invertedStyle ? _invertedStyle : undefined];
152
+ if (isLoading || !topic) {
153
+ return _jsx(Wrapper, {
154
+ css: wrapperStyle,
155
+ "data-testid": testId,
156
+ children: isLoading ? _jsx(Loader, {}) : null
157
+ });
158
+ }
159
+ return _jsxs(Wrapper, {
160
+ css: wrapperStyle,
161
+ "data-testid": testId,
162
+ children: [_jsxs(TopicIntroductionWrapper, {
163
+ children: [_jsxs("div", {
164
+ children: [_jsxs(HeadingWrapper, {
165
+ children: [_jsx("h1", {
166
+ id: id,
167
+ tabIndex: -1,
246
168
  children: topic.title
247
- }), isAdditionalTopic && _jsxs(StyledAdditionalResource, {
248
- children: [_jsx(StyledAdditionalResourceMark, {
169
+ }), isAdditionalTopic && _jsxs(_Fragment, {
170
+ children: [_jsx(AdditionalIcon, {
171
+ "aria-hidden": "true",
249
172
  children: "T"
250
- }), t('navigation.additionalTopic')]
173
+ }), _jsx("span", {
174
+ children: t('navigation.additionalTopic')
175
+ })]
251
176
  })]
252
- }), messageBox && _jsx(MessageBox, {
253
- children: messageBox
254
177
  }), _jsx(TopicIntroduction, {
255
- invertedStyle: invertedStyle,
256
178
  children: renderMarkdown ? parse(renderMarkdown(topic.introduction)) : topic.introduction
257
- }), onToggleShowContent && _jsx(StyledButtonWrapper, {
258
- invertedStyle: invertedStyle,
259
- children: _jsx(Button, {
260
- "aria-expanded": !!showContent,
261
- link: true,
262
- onClick: function onClick() {
263
- onToggleShowContent();
264
- },
265
- children: showContent ? _jsxs(_Fragment, {
266
- children: [t('navigation.showShorterDescription'), " ", _jsx(ChevronUp, {})]
267
- }) : _jsxs(_Fragment, {
268
- children: [t('navigation.showLongerDescription'), " ", _jsx(ChevronDown, {})]
269
- })
270
- })
271
- }), showContent && _jsx(StyledContentWrapper, {
272
- invertedStyle: invertedStyle,
273
- children: children
274
- }), subTopics && subTopics.length !== 0 && _jsx(StyledNavigationBoxWrapper, {
275
- children: _jsx(NavigationBox, {
276
- colorMode: "light",
277
- heading: t('navigation.topics'),
278
- items: subTopics,
279
- onClick: onSubTopicSelected,
280
- invertedStyle: invertedStyle
179
+ })]
180
+ }), topic.image && _jsx(TopicHeaderVisualElementWrapper, {
181
+ children: topic.visualElement ? _jsx(ModalV2, {
182
+ label: t('topicPage.imageModal'),
183
+ activateButton: _jsxs(VisualElementButton, {
184
+ variant: "stripped",
185
+ title: topic.visualElement.type === 'image' ? t('image.largeSize') : t('visualElement.show'),
186
+ children: [_jsxs(ShowVisualElementWrapper, {
187
+ children: [_jsx(TopicHeaderImage, {
188
+ src: "".concat(topic.image.url, "?").concat(makeSrcQueryString(800, topic.image.crop, topic.image.focalPoint)),
189
+ alt: topic.image.alt
190
+ }), _jsx(TopicHeaderOverlay, {})]
191
+ }), _jsx(ExpandVisualElementButton, {
192
+ children: VisualElementIcon && _jsx(VisualElementIcon, {})
193
+ })]
194
+ }),
195
+ animation: "subtle",
196
+ animationDuration: 50,
197
+ size: "large",
198
+ children: function children(onClose) {
199
+ return _jsxs(_Fragment, {
200
+ children: [_jsx(ModalHeader, {
201
+ children: _jsx(ModalCloseButton, {
202
+ onClick: onClose,
203
+ title: t('modal.closeModal')
204
+ })
205
+ }), topic.visualElement && topic.visualElement.element]
206
+ });
207
+ }
208
+ }) : _jsx(TopicHeaderImage, {
209
+ src: "".concat(topic.image.url, "?").concat(makeSrcQueryString(400, topic.image.crop, topic.image.focalPoint)),
210
+ alt: topic.image.alt
211
+ })
212
+ })]
213
+ }), messageBox && _jsx(MessageBox, {
214
+ children: messageBox
215
+ }), _jsxs("div", {
216
+ children: [onToggleShowContent && _jsx(StyledButtonWrapper, {
217
+ invertedStyle: invertedStyle,
218
+ children: _jsx(ButtonV2, {
219
+ "aria-expanded": !!showContent,
220
+ "aria-controls": contentId,
221
+ variant: "link",
222
+ onClick: function onClick() {
223
+ return onToggleShowContent();
224
+ },
225
+ children: showContent ? _jsxs(_Fragment, {
226
+ children: [t('navigation.showShorterDescription'), " ", _jsx(ChevronUp, {})]
227
+ }) : _jsxs(_Fragment, {
228
+ children: [t('navigation.showLongerDescription'), " ", _jsx(ChevronDown, {})]
281
229
  })
282
- }), topic.resources]
283
- })
284
- })
230
+ })
231
+ }), showContent && _jsx(StyledContentWrapper, {
232
+ id: contentId,
233
+ invertedStyle: invertedStyle,
234
+ children: children
235
+ })]
236
+ }), subTopics && subTopics.length !== 0 && _jsx(NavigationBox, {
237
+ colorMode: "light",
238
+ heading: t('navigation.topics'),
239
+ items: subTopics,
240
+ onClick: onSubTopicSelected,
241
+ invertedStyle: invertedStyle
242
+ }), topic.resources]
285
243
  });
286
244
  };
287
245
  export default Topic;