@ndla/ui 6.1.3 → 6.2.2

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.
@@ -16,13 +16,16 @@ import { jsx as ___EmotionJSX } from "@emotion/core";
16
16
  var ConceptNotion = function ConceptNotion(_ref) {
17
17
  var _concept$copyright$li, _concept$copyright, _concept$copyright$li2, _concept$subjectNames, _concept$visualElemen, _concept$visualElemen2;
18
18
 
19
- var concept = _ref.concept;
19
+ var concept = _ref.concept,
20
+ disableScripts = _ref.disableScripts;
20
21
  var notionId = "notion-".concat(concept.id);
21
22
  var figureId = "notion-figure-".concat(concept.id);
22
23
  var visualElementId = "visual-element-".concat(concept.id);
23
24
  useEffect(function () {
24
- initArticleScripts();
25
- }, []);
25
+ if (!disableScripts) {
26
+ initArticleScripts();
27
+ }
28
+ }, [disableScripts]);
26
29
  return ___EmotionJSX(FigureNotion, {
27
30
  id: figureId,
28
31
  figureId: visualElementId,
@@ -38,7 +38,7 @@ import { jsx as ___EmotionJSX } from "@emotion/core";
38
38
  var NotionContainer = _styled("div", {
39
39
  target: "eztjhst0",
40
40
  label: "NotionContainer"
41
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAmBkC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
41
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAmBkC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
42
42
 
43
43
  var ContentWrapper = _styled("div", {
44
44
  target: "eztjhst1",
@@ -47,19 +47,21 @@ var ContentWrapper = _styled("div", {
47
47
  until: breakpoints.tabletWide
48
48
  }), "{display:flex;flex-direction:column-reverse;}.c-figure{margin:0;position:relative !important;left:0 !important;width:25% !important;padding:0 0 0 20px;float:right;&.expanded{width:100% !important;padding:0;margin-bottom:", spacing.normal, ";}", mq.range({
49
49
  until: breakpoints.tabletWide
50
- }), "{width:100% !important;padding:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAqBiC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
50
+ }), "{width:100% !important;padding:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAqBiC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
51
51
 
52
52
  var TextWrapper = _styled("div", {
53
53
  target: "eztjhst2",
54
54
  label: "TextWrapper"
55
- })("width:75%;", mq.range({
55
+ })("width:", function (props) {
56
+ return props.hasVisualElement ? '75%' : '100%';
57
+ }, ";", mq.range({
56
58
  until: breakpoints.tabletWide
57
- }), "{width:100%;}font-family:", fonts.serif, ";", fonts.sizes('18px', '28px'), ";", ContentWrapper, " .c-figure.expanded + &{width:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA4C8B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
59
+ }), "{width:100%;}font-family:", fonts.serif, ";", fonts.sizes('18px', '28px'), ";", ContentWrapper, " .c-figure.expanded + &{width:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA4C6D","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
58
60
 
59
61
  var ImageElement = _styled("img", {
60
62
  target: "eztjhst3",
61
63
  label: "ImageElement"
62
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAwD+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
64
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAwD+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
63
65
 
64
66
  var fadeInMediaKeyframe = keyframes(_templateObject());
65
67
  var fadeOutMediaKeyframe = keyframes(_templateObject2());
@@ -69,22 +71,22 @@ var ImageWrapper = _styled("div", {
69
71
  label: "ImageWrapper"
70
72
  })("float:right;width:25%;padding-left:", spacing.normal, ";position:relative;", mq.range({
71
73
  until: breakpoints.tabletWide
72
- }), "{width:100%;padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+E+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
74
+ }), "{width:100%;padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+E+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
73
75
 
74
76
  var ExpandVisualElementButton = /*#__PURE__*/_styled(Button, {
75
77
  target: "eztjhst5",
76
78
  label: "ExpandVisualElementButton"
77
- })("position:absolute;right:8px;bottom:8px;transition:all ", animations.durations.normal, ";&,&:focus,&:active{background-color:rgba(255,255,255,0.65);}color:", colors.brand.primary, ";border-radius:50%;border:0;width:40px;height:40px;display:inline-flex;justify-content:center;align-items:center;svg{transition:transform ", animations.durations.normal, " ease-out;}", ContentWrapper, ":hover &{background-color:#fff;svg{transform:scale(1.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA2FgD","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
79
+ })("position:absolute;right:8px;bottom:8px;transition:all ", animations.durations.normal, ";&,&:focus,&:active{background-color:rgba(255,255,255,0.65);}color:", colors.brand.primary, ";border-radius:50%;border:0;width:40px;height:40px;display:inline-flex;justify-content:center;align-items:center;svg{transition:transform ", animations.durations.normal, " ease-out;}", ContentWrapper, ":hover &{background-color:#fff;svg{transform:scale(1.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA2FgD","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
78
80
 
79
81
  var ExpandIcon = _styled("span", {
80
82
  target: "eztjhst6",
81
83
  label: "ExpandIcon"
82
- })(ExpandVisualElementButton, ".expanded &{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0H8B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
84
+ })(ExpandVisualElementButton, ".expanded &{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0H8B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
83
85
 
84
86
  var CollapseIcon = _styled("span", {
85
87
  target: "eztjhst7",
86
88
  label: "CollapseIcon"
87
- })("display:none;", ExpandVisualElementButton, ".expanded &{display:inline-block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+HgC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
89
+ })("display:none;", ExpandVisualElementButton, ".expanded &{display:inline-block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+HgC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
88
90
 
89
91
  var ClearWrapper = _styled("div", {
90
92
  target: "eztjhst8",
@@ -95,19 +97,19 @@ var ClearWrapper = _styled("div", {
95
97
  } : {
96
98
  name: "1xa411s",
97
99
  styles: "clear:both;",
98
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAsI+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */",
100
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAsI+B","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */",
99
101
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
100
102
  });
101
103
 
102
104
  var MediaContainer = _styled("div", {
103
105
  target: "eztjhst9",
104
106
  label: "MediaContainer"
105
- })("opacity:0;height:0;overflow:hidden;&.expanded{animation-name:", fadeInMediaKeyframe, ";animation-duration:2.8s;opacity:1;height:auto;}&.fadeOut{animation-name:", fadeOutMediaKeyframe, ";animation-duration:2.8s;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0IiC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
107
+ })("opacity:0;height:0;overflow:hidden;&.expanded{animation-name:", fadeInMediaKeyframe, ";animation-duration:2.8s;opacity:1;height:auto;}&.fadeOut{animation-name:", fadeOutMediaKeyframe, ";animation-duration:2.8s;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0IiC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
106
108
 
107
109
  var LabelsContainer = _styled("div", {
108
110
  target: "eztjhst10",
109
111
  label: "LabelsContainer"
110
- })("display:flex;align-items:center;", fonts.sizes('14px', '24px'), ";font-family:", fonts.sans, ";margin:", spacing.small, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0JkC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
112
+ })("display:flex;align-items:center;", fonts.sizes('14px', '24px'), ";font-family:", fonts.sans, ";margin:", spacing.small, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0JkC","file":"Notion.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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div<{ hasVisualElement: boolean }>`\n  width: ${(props) => (props.hasVisualElement ? '75%' : '100%')};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper hasVisualElement={!!(imageElement || visualElement?.metaImage)}>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
111
113
 
112
114
  var Notion = function Notion(_ref) {
113
115
  var id = _ref.id,
@@ -147,7 +149,9 @@ var Notion = function Notion(_ref) {
147
149
  width: '24px',
148
150
  height: '24px'
149
151
  }
150
- })))), ___EmotionJSX(TextWrapper, null, HTMLReactParser(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text)), !!labels.length && ___EmotionJSX(LabelsContainer, null, t('searchPage.resultType.notionLabels'), labels.map(function (label, i) {
152
+ })))), ___EmotionJSX(TextWrapper, {
153
+ hasVisualElement: !!(imageElement || (visualElement === null || visualElement === void 0 ? void 0 : visualElement.metaImage))
154
+ }, HTMLReactParser(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text)), !!labels.length && ___EmotionJSX(LabelsContainer, null, t('searchPage.resultType.notionLabels'), labels.map(function (label, i) {
151
155
  return ___EmotionJSX(Fragment, {
152
156
  key: "notion-".concat(id, "-label-").concat(i + 1)
153
157
  }, ' ', label, i < (labels === null || labels === void 0 ? void 0 : labels.length) - 1 && ___EmotionJSX(React.Fragment, null, " \u2022"));