@ndla/ui 34.7.0 → 35.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -72,29 +72,29 @@ var notionContentCss = /*#__PURE__*/css("@keyframes animateIn{0%{opacity:0;trans
72
72
  from: breakpoints.desktop
73
73
  }), "{width:720px;}", mq.range({
74
74
  until: breakpoints.tablet
75
- }), "{padding:", spacing.small, ";z-index:9999;height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmF4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
75
+ }), "{padding:", spacing.small, ";z-index:9999;height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmF4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
76
76
  var StyledIframe = /*#__PURE__*/_styled("iframe", {
77
77
  target: "eqcj3r9",
78
78
  label: "StyledIframe"
79
79
  })("height:auto;min-height:", function (p) {
80
80
  return p.type === 'video' && '400px';
81
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqHqD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
81
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqHqD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
82
82
  var NotionHeader = /*#__PURE__*/_styled("div", {
83
83
  target: "eqcj3r8",
84
84
  label: "NotionHeader"
85
- })("display:flex;align-items:center;justify-content:flex-end;border-bottom:2px solid ", colors.brand.tertiary, ";padding-bottom:", spacing.small, ";h1{flex-grow:1;margin:0;font-weight:", fonts.weight.bold, ";", fonts.sizes('22px', 1.2), ";}small{padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";border-left:1px solid ", colors.brand.greyLight, ";", fonts.sizes('20px', 1.2), ";font-weight:", fonts.weight.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA0H+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
85
+ })("display:flex;align-items:center;justify-content:flex-end;border-bottom:2px solid ", colors.brand.tertiary, ";padding-bottom:", spacing.small, ";h1{flex-grow:1;margin:0;font-weight:", fonts.weight.bold, ";", fonts.sizes('22px', 1.2), ";}small{padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";border-left:1px solid ", colors.brand.greyLight, ";", fonts.sizes('20px', 1.2), ";font-weight:", fonts.weight.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA0H+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
86
86
  var StyledAccordionContent = /*#__PURE__*/_styled(Content, {
87
87
  target: "eqcj3r7",
88
88
  label: "StyledAccordionContent"
89
- })("background-color:", colors.brand.lighter, ";padding:", spacing.small, ";border-radius:", misc.borderRadius, ";overflow:hidden;&[data-state='open']{animation:slideDown 300ms ease-out;}&[data-state='closed']{animation:slideUp 300ms ease-out;}@keyframes slideDown{from{height:0;}to{height:var(--radix-accordion-content-height);}}@keyframes slideUp{from{height:var(--radix-accordion-content-height);}to{height:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+I8C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
89
+ })("background-color:", colors.brand.lighter, ";padding:", spacing.small, ";border-radius:", misc.borderRadius, ";overflow:hidden;&[data-state='open']{animation:slideDown 300ms ease-out;}&[data-state='closed']{animation:slideUp 300ms ease-out;}@keyframes slideDown{from{height:0;}to{height:var(--radix-accordion-content-height);}}@keyframes slideUp{from{height:var(--radix-accordion-content-height);}to{height:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+I8C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
90
90
  var StyledRoot = /*#__PURE__*/_styled(Root, {
91
91
  target: "eqcj3r6",
92
92
  label: "StyledRoot"
93
- })("border-bottom:1px solid ", colors.brand.greyLight, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA4K+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
93
+ })("border-bottom:1px solid ", colors.brand.greyLight, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA4K+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
94
94
  var StyledFigure = /*#__PURE__*/_styled(Figure, {
95
95
  target: "eqcj3r5",
96
96
  label: "StyledFigure"
97
- })("&&{margin:", spacing.normal, " 0;}padding-bottom:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAgLmC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
97
+ })("&&{margin:", spacing.normal, " 0;}padding-bottom:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAgLmC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
98
98
  var StyledFigureCaption = /*#__PURE__*/_styled(FigureCaption, {
99
99
  target: "eqcj3r4",
100
100
  label: "StyledFigureCaption"
@@ -104,7 +104,7 @@ var StyledFigureCaption = /*#__PURE__*/_styled(FigureCaption, {
104
104
  } : {
105
105
  name: "1s3qw3i",
106
106
  styles: "border-bottom:0;h3{margin:0;}",
107
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuLiD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
107
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuLiD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
108
108
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
109
109
  });
110
110
  var StyledSpan = /*#__PURE__*/_styled("span", {
@@ -116,21 +116,21 @@ var StyledSpan = /*#__PURE__*/_styled("span", {
116
116
  } : {
117
117
  name: "1t01il3",
118
118
  styles: "font-style:italic;color:grey",
119
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+L8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
119
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+L8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
120
120
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
121
121
  });
122
122
  var StyledAccordionTrigger = /*#__PURE__*/_styled(ButtonV2, {
123
123
  target: "eqcj3r2",
124
124
  label: "StyledAccordionTrigger"
125
- })("color:", colors.brand.primary, ";border-color:", colors.brand.primary, ";&[data-state='open']{svg{transform:rotate(180deg);}}svg{transition:transform 300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoM+C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
125
+ })("color:", colors.brand.primary, ";border-color:", colors.brand.primary, ";&[data-state='open']{svg{transform:rotate(180deg);}}svg{transition:transform 300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoM+C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
126
126
  var ListWrapper = /*#__PURE__*/_styled("div", {
127
127
  target: "eqcj3r1",
128
128
  label: "ListWrapper"
129
- })("display:flex;gap:", spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAiN8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
129
+ })("display:flex;gap:", spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAiN8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
130
130
  var StyledList = /*#__PURE__*/_styled("ul", {
131
131
  target: "eqcj3r0",
132
132
  label: "StyledList"
133
- })("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{margin:0;font-family:", fonts.sans, ";font-weight:", fonts.weight.semibold, ";border-radius:", misc.borderRadius, ";background-color:", colors.brand.greyLightest, ";", fonts.sizes('12px', 1.2), ";padding:", spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuN4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
133
+ })("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{margin:0;font-family:", fonts.sans, ";font-weight:", fonts.weight.semibold, ";border-radius:", misc.borderRadius, ";background-color:", colors.brand.greyLightest, ";", fonts.sizes('12px', 1.2), ";padding:", spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuN4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n        iframe.width = '';\n        iframe.height = '';\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
134
134
  export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
135
135
  var _notionVisualElement$, _notionVisualElement$2, _notionVisualElement$3, _notionVisualElement$4, _notionVisualElement$5, _notionVisualElement$6, _notionVisualElement$7, _copyright$license$li, _copyright$license;
136
136
  var visualElement = _ref.visualElement,
@@ -156,6 +156,8 @@ export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
156
156
  width = _ref2[0],
157
157
  height = _ref2[1];
158
158
  iframe.style.aspectRatio = "".concat(width ? width : 16, "/").concat(height ? height : 9);
159
+ iframe.width = '';
160
+ iframe.height = '';
159
161
  }
160
162
  }, []);
161
163
  var licenseCredits = getLicenseCredits(copyright);