@ndla/ui 7.0.0 → 8.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -57,7 +57,6 @@ var FigureNotion = function FigureNotion(_ref) {
57
57
  hideFigcaption: hideFigCaption,
58
58
  figureId: figureId,
59
59
  id: id,
60
- caption: title,
61
60
  reuseLabel: t("".concat(type, ".reuse")),
62
61
  authors: contributors,
63
62
  licenseRights: license.rights
@@ -25,7 +25,7 @@ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(
25
25
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
26
26
 
27
27
  import { useTranslation } from 'react-i18next';
28
- import HTMLReactParser from 'html-react-parser';
28
+ import { parseMarkdown } from '@ndla/util';
29
29
  import React, { Fragment } from 'react';
30
30
  import { keyframes } from '@emotion/core';
31
31
  import Button from '@ndla/button';
@@ -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<{ 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"]} */");
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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,7 +47,7 @@ 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<{ 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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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",
@@ -56,12 +56,12 @@ var TextWrapper = _styled("div", {
56
56
  return props.hasVisualElement ? '75%' : '100%';
57
57
  }, ";", mq.range({
58
58
  until: breakpoints.tabletWide
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
60
60
 
61
61
  var ImageElement = _styled("img", {
62
62
  target: "eztjhst3",
63
63
  label: "ImageElement"
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"]} */");
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */");
65
65
 
66
66
  var fadeInMediaKeyframe = keyframes(_templateObject());
67
67
  var fadeOutMediaKeyframe = keyframes(_templateObject2());
@@ -71,22 +71,22 @@ var ImageWrapper = _styled("div", {
71
71
  label: "ImageWrapper"
72
72
  })("float:right;width:25%;padding-left:", spacing.normal, ";position:relative;", mq.range({
73
73
  until: breakpoints.tabletWide
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
75
75
 
76
76
  var ExpandVisualElementButton = /*#__PURE__*/_styled(Button, {
77
77
  target: "eztjhst5",
78
78
  label: "ExpandVisualElementButton"
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
80
80
 
81
81
  var ExpandIcon = _styled("span", {
82
82
  target: "eztjhst6",
83
83
  label: "ExpandIcon"
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
85
85
 
86
86
  var CollapseIcon = _styled("span", {
87
87
  target: "eztjhst7",
88
88
  label: "CollapseIcon"
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
90
90
 
91
91
  var ClearWrapper = _styled("div", {
92
92
  target: "eztjhst8",
@@ -97,25 +97,24 @@ var ClearWrapper = _styled("div", {
97
97
  } : {
98
98
  name: "1xa411s",
99
99
  styles: "clear:both;",
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"]} */",
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */",
101
101
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
102
102
  });
103
103
 
104
104
  var MediaContainer = _styled("div", {
105
105
  target: "eztjhst9",
106
106
  label: "MediaContainer"
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
108
108
 
109
109
  var LabelsContainer = _styled("div", {
110
110
  target: "eztjhst10",
111
111
  label: "LabelsContainer"
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"]} */"));
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 { parseMarkdown } from '@ndla/util';\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  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({ id, labels = [], text, title, visualElement, imageElement, children }: 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          {parseMarkdown(`**${title}** \\u2013 ${text}`)}\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"]} */"));
113
113
 
114
114
  var Notion = function Notion(_ref) {
115
115
  var id = _ref.id,
116
116
  _ref$labels = _ref.labels,
117
117
  labels = _ref$labels === void 0 ? [] : _ref$labels,
118
- renderMarkdown = _ref.renderMarkdown,
119
118
  text = _ref.text,
120
119
  title = _ref.title,
121
120
  visualElement = _ref.visualElement,
@@ -151,7 +150,7 @@ var Notion = function Notion(_ref) {
151
150
  }
152
151
  })))), ___EmotionJSX(TextWrapper, {
153
152
  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) {
153
+ }, parseMarkdown("**".concat(title, "** \u2013 ").concat(text)), !!labels.length && ___EmotionJSX(LabelsContainer, null, t('searchPage.resultType.notionLabels'), labels.map(function (label, i) {
155
154
  return ___EmotionJSX(Fragment, {
156
155
  key: "notion-".concat(id, "-label-").concat(i + 1)
157
156
  }, ' ', label, i < (labels === null || labels === void 0 ? void 0 : labels.length) - 1 && ___EmotionJSX(React.Fragment, null, " \u2022"));
@@ -7,7 +7,7 @@
7
7
  import React from 'react';
8
8
  import FigureNotion from './FigureNotion';
9
9
  import { jsx as ___EmotionJSX } from "@emotion/core";
10
- var supportedEmbedTypes = ['brightcove', 'h5p'];
10
+ var supportedEmbedTypes = ['brightcove', 'h5p', 'iframe', 'external'];
11
11
 
12
12
  var NotionVisualElement = function NotionVisualElement(_ref) {
13
13
  var _visualElement$title, _visualElement$copyri, _visualElement$copyri2, _visualElement$copyri3;
@@ -71,7 +71,6 @@ var FigureNotion = function FigureNotion(_ref) {
71
71
  hideFigcaption: hideFigCaption,
72
72
  figureId: figureId,
73
73
  id: id,
74
- caption: title,
75
74
  reuseLabel: t("".concat(type, ".reuse")),
76
75
  authors: contributors,
77
76
  licenseRights: license.rights
@@ -20,12 +20,11 @@ declare type VisualElementProps = {
20
20
  export declare type NotionProps = {
21
21
  id: string | number;
22
22
  labels?: string[];
23
- renderMarkdown?: (text: string) => string;
24
23
  text: ReactNode;
25
24
  title: string;
26
25
  visualElement?: VisualElementProps;
27
26
  imageElement?: ReactNode;
28
27
  children?: ReactNode;
29
28
  };
30
- declare const Notion: ({ id, labels, renderMarkdown, text, title, visualElement, imageElement, children, }: NotionProps) => JSX.Element;
29
+ declare const Notion: ({ id, labels, text, title, visualElement, imageElement, children }: NotionProps) => JSX.Element;
31
30
  export default Notion;