@ndla/ui 3.3.11 → 3.3.12

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.
@@ -8,7 +8,7 @@
8
8
  import React from 'react';
9
9
  import { NotionMedia } from '../types';
10
10
  export declare type SearchNotionItemProps = {
11
- id: string;
11
+ id: string | number;
12
12
  title: string;
13
13
  text: React.ReactNode;
14
14
  image?: {
@@ -46,31 +46,31 @@ var ItemWrapper = (0, _styledBase["default"])("div", {
46
46
  return props.hasMedia && "".concat(_core.mq.range({
47
47
  from: _core.breakpoints.tabletWide
48
48
  }), " {\n display: grid;\n grid-template-columns: 2fr 1fr;\n column-gap: ").concat(_core.spacing.medium, ";\n align-items: start;\n }");
49
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA8BgD","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */");
49
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA8BgD","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */");
50
50
  var TextWrapper = (0, _styledBase["default"])("div", {
51
51
  target: "ek7i9z41",
52
52
  label: "TextWrapper"
53
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA+C8B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */");
53
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA+C8B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */");
54
54
  var DescriptionWrapper = (0, _styledBase["default"])("div", {
55
55
  target: "ek7i9z42",
56
56
  label: "DescriptionWrapper"
57
- })(_core.fonts.sizes('18px', '26px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAgDqC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
57
+ })(_core.fonts.sizes('18px', '26px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAgDqC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
58
58
  var MediaWrapper = (0, _styledBase["default"])("div", {
59
59
  target: "ek7i9z43",
60
60
  label: "MediaWrapper"
61
- })("margin-bottom:", _core.spacing.normal, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAoD+B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
61
+ })("margin-bottom:", _core.spacing.normal, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAoD+B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
62
62
  var LabelsWrapper = (0, _styledBase["default"])("div", {
63
63
  target: "ek7i9z44",
64
64
  label: "LabelsWrapper"
65
- })("display:flex;flex-wrap:wrap;margin-top:", _core.spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAwDgC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
65
+ })("display:flex;flex-wrap:wrap;margin-top:", _core.spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAwDgC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
66
66
  var LabelsLabel = (0, _styledBase["default"])("span", {
67
67
  target: "ek7i9z45",
68
68
  label: "LabelsLabel"
69
- })("display:inline-block;", _core.fonts.sizes('16px', '20px'), ";margin-right:4px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA6D+B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
69
+ })("display:inline-block;", _core.fonts.sizes('16px', '20px'), ";margin-right:4px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA6D+B","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
70
70
  var Label = (0, _styledBase["default"])("span", {
71
71
  target: "ek7i9z46",
72
72
  label: "Label"
73
- })("display:inline-block;background:", _core.colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.fonts.weight.semibold, ";margin:0 4px 4px 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAkEyB","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
73
+ })("display:inline-block;background:", _core.colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.fonts.weight.semibold, ";margin:0 4px 4px 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAkEyB","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */"));
74
74
  var Image = (0, _styledBase["default"])("img", {
75
75
  target: "ek7i9z47",
76
76
  label: "Image"
@@ -80,7 +80,7 @@ var Image = (0, _styledBase["default"])("img", {
80
80
  } : {
81
81
  name: "quva1q",
82
82
  styles: "border-radius:5px;",
83
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA4EwB","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
83
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA4EwB","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
84
84
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
85
  });
86
86
  var ShowMediaWrapper = (0, _styledBase["default"])("div", {
@@ -92,7 +92,7 @@ var ShowMediaWrapper = (0, _styledBase["default"])("div", {
92
92
  } : {
93
93
  name: "m1yo5r",
94
94
  styles: "display:flex;justify-content:center;align-items:center;position:absolute;top:0;left:0;right:0;bottom:0;&:after{background:#000;content:'';display:block;position:absolute;top:0;left:0;right:0;bottom:0;opacity:0.4;}",
95
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAgFmC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
95
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAgFmC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
96
96
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
97
97
  });
98
98
  var ShowMediaButtonWrapper = (0, _styledBase["default"])("div", {
@@ -104,7 +104,7 @@ var ShowMediaButtonWrapper = (0, _styledBase["default"])("div", {
104
104
  } : {
105
105
  name: "r6z5ec",
106
106
  styles: "z-index:1;",
107
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAqGyC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
107
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAqGyC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
108
108
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
109
109
  });
110
110
  var ShowMediaButtonText = (0, _styledBase["default"])("span", {
@@ -116,7 +116,7 @@ var ShowMediaButtonText = (0, _styledBase["default"])("span", {
116
116
  } : {
117
117
  name: "15fzge",
118
118
  styles: "margin-left:4px;",
119
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAwGuC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
119
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AAwGuC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
120
120
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
121
121
  });
122
122
  var AuthorsWrapper = (0, _styledBase["default"])("div", {
@@ -128,7 +128,7 @@ var AuthorsWrapper = (0, _styledBase["default"])("div", {
128
128
  } : {
129
129
  name: "1o4k933",
130
130
  styles: "margin:1rem 0;p{margin:0;font-size:0.875rem;}button{margin-left:1rem;}",
131
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA4GiC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
131
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchNotionItem.tsx"],"names":[],"mappings":"AA4GiC","file":"SearchNotionItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n// @ts-ignore\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport { Play } from '@ndla/icons/common';\n// @ts-ignore\nimport { ArrowExpand } from '@ndla/icons/editor';\n// @ts-ignore\nimport Modal, { ModalCloseButton, ModalHeader, ModalBody } from '@ndla/modal';\nimport { useTranslation } from 'react-i18next';\nimport { joinArrayWithConjunction } from '@ndla/util';\nimport { NotionMedia } from '../types';\n\ntype ItemWrapperProps = {\n  hasMedia?: boolean;\n};\nconst ItemWrapper = styled.div<ItemWrapperProps>`\n  border-top: 2px solid ${colors.brand.light};\n  padding: ${spacing.medium} 0;\n  display: flex;\n  flex-direction: column-reverse;\n  align-items: center;\n\n  ${(props) =>\n    props.hasMedia &&\n    `${mq.range({ from: breakpoints.tabletWide })} {\n    display: grid;\n    grid-template-columns: 2fr 1fr;\n    column-gap: ${spacing.medium};\n    align-items: start;\n  }`}\n`;\n\nconst TextWrapper = styled.div``;\nconst DescriptionWrapper = styled.div`\n  ${fonts.sizes('18px', '26px')};\n`;\n\nconst MediaWrapper = styled.div`\n  margin-bottom: ${spacing.normal};\n  position: relative;\n`;\nconst LabelsWrapper = styled.div`\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: ${spacing.normal};\n`;\nconst LabelsLabel = styled.span`\n  display: inline-block;\n  ${fonts.sizes('16px', '20px')};\n  margin-right: 4px;\n`;\nconst Label = styled.span`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 0 4px 4px 0;\n`;\n\nconst Image = styled.img`\n  border-radius: 5px;\n`;\n\nconst ShowMediaWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  &:after {\n    background: #000;\n    content: '';\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    opacity: 0.4;\n  }\n`;\nconst ShowMediaButtonWrapper = styled.div`\n  z-index: 1;\n`;\nconst ShowMediaButtonText = styled.span`\n  margin-left: 4px;\n`;\n\nconst AuthorsWrapper = styled.div`\n  margin: 1rem 0;\n\n  p {\n    margin: 0;\n    font-size: 0.875rem;\n  }\n\n  button {\n    margin-left: 1rem;\n  }\n`;\n\nexport type SearchNotionItemProps = {\n  id: string | number;\n  title: string;\n  text: React.ReactNode;\n  image?: { url: string; alt: string };\n  media?: NotionMedia;\n  labels?: string[];\n  authors?: { name: string }[];\n  license?: string;\n  locale?: string;\n  onReferenceClick?: React.MouseEventHandler<HTMLButtonElement>;\n  renderMarkdown: (text: React.ReactNode) => string;\n};\n\nconst SearchNotionItem = ({\n  title,\n  text,\n  image,\n  media,\n  labels = [],\n  authors = [],\n  license,\n  locale,\n  onReferenceClick,\n  renderMarkdown,\n}: SearchNotionItemProps) => {\n  const { t } = useTranslation();\n  const hasMedia = !!(image || media);\n  const ShowMediaButton = ({ type, element }: NotionMedia) => {\n    return (\n      <ShowMediaButtonWrapper>\n        <Modal\n          activateButton={\n            <Button lighter size=\"xsmall\" borderShape=\"rounded\">\n              {type === 'video' && (\n                <>\n                  <Play />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showVideo')}</ShowMediaButtonText>\n                </>\n              )}\n              {type === 'other' && (\n                <>\n                  <ArrowExpand />\n                  <ShowMediaButtonText>{t('searchPage.resultType.showNotion')}</ShowMediaButtonText>\n                </>\n              )}\n            </Button>\n          }\n          animation=\"subtle\"\n          animationDuration={50}\n          backgroundColor=\"white\"\n          size=\"medium\">\n          {(onClose: () => void) => (\n            <>\n              <ModalHeader>\n                <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n              </ModalHeader>\n              <ModalBody modifier=\"no-side-padding-mobile\">{element}</ModalBody>\n            </>\n          )}\n        </Modal>\n      </ShowMediaButtonWrapper>\n    );\n  };\n\n  return (\n    <ItemWrapper hasMedia={hasMedia}>\n      <TextWrapper>\n        <DescriptionWrapper>\n          {parse(renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`)}\n        </DescriptionWrapper>\n        {(authors || license) && (\n          <AuthorsWrapper>\n            {\n              <p>\n                {authors.length > 0 &&\n                  t('article.writtenBy', {\n                    authors:\n                      joinArrayWithConjunction(\n                        authors.map((author) => author.name),\n                        { conjunction: ` ${t('article.conjunction')} ` },\n                      ) || '',\n                  })}\n                {authors.length > 0 && license && ' '}\n                {license && `(${getLicenseByAbbreviation(license, locale).abbreviation})`}\n                {onReferenceClick && (\n                  <Button link onClick={onReferenceClick}>\n                    {t('article.cite')}\n                  </Button>\n                )}\n              </p>\n            }\n          </AuthorsWrapper>\n        )}\n        {labels.length > 0 && (\n          <LabelsWrapper>\n            <LabelsLabel>{t('searchPage.resultType.notionLabels')}:</LabelsLabel>\n            {labels.map((label) => (\n              <Label key={label}>{label}</Label>\n            ))}\n          </LabelsWrapper>\n        )}\n      </TextWrapper>\n      {hasMedia && (\n        <MediaWrapper>\n          {image && <Image src={image.url} alt={image.alt} />}\n          {media && (\n            <ShowMediaWrapper>\n              <ShowMediaButton type={media.type} element={media.element} />\n            </ShowMediaWrapper>\n          )}\n        </MediaWrapper>\n      )}\n    </ItemWrapper>\n  );\n};\n\nexport default SearchNotionItem;\n"]} */",
132
132
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
133
133
  });
134
134
 
@@ -10,4 +10,5 @@ import SearchHeader from './SearchHeader';
10
10
  import SearchFieldHeader from './SearchFieldHeader';
11
11
  import SearchNotionsResult from './SearchNotionsResult';
12
12
  import SearchSubjectResult from './SearchSubjectResult';
13
+ export type { ContentType } from './SearchTypeResult';
13
14
  export { SearchTypeResult, SearchHeader, SearchFieldHeader, SearchNotionsResult, SearchSubjectResult };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "3.3.11",
3
+ "version": "3.3.12",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -92,5 +92,5 @@
92
92
  "publishConfig": {
93
93
  "access": "public"
94
94
  },
95
- "gitHead": "931121c140745578c341fff16a8d8eeb6fd918ee"
95
+ "gitHead": "ff7194a882009a1b4faddafdad34a949d4426ffb"
96
96
  }