@ndla/ui 45.0.13 → 45.0.14

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.
@@ -1,6 +1,6 @@
1
1
  function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
2
  import _styled from "@emotion/styled/base";
3
- var _excluded = ["visualElement", "title", "content", "source", "copyright", "closeButton", "inPopover", "previewAlt", "tags", "subjects", "heartButton", "conceptHeartButton", "conceptType", "glossData"];
3
+ var _excluded = ["visualElement", "title", "content", "source", "copyright", "closeButton", "inPopover", "previewAlt", "tags", "subjects", "heartButton", "conceptHeartButton", "conceptType", "glossData", "headerButtons"];
4
4
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
5
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
6
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
@@ -33,32 +33,36 @@ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
33
33
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
34
34
  import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
35
35
  var ContentPadding = /*#__PURE__*/_styled("div", {
36
- target: "eqcj3r4",
36
+ target: "eqcj3r5",
37
37
  label: "ContentPadding"
38
- })("padding:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoDiC","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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
38
+ })("padding:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqDiC","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
39
39
  var notionContentCss = /*#__PURE__*/css("@keyframes animateIn{0%{opacity:0;transform:translate3d(0, -13px, 0);}100%{opacity:1;transform:translate3d(0, 0, 0);}}animation-name:animateIn;animation-duration:300ms;background-color:white;z-index:1;box-shadow:0 0 30px rgba(0, 0, 0, 0.2);", mq.range({
40
40
  from: breakpoints.tablet
41
41
  }), "{width:500px;}", mq.range({
42
42
  from: breakpoints.desktop
43
43
  }), "{width:720px;}", mq.range({
44
44
  until: breakpoints.tablet
45
- }), "{padding:", spacing.small, ";z-index:100;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":"AAwD4B","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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
45
+ }), "{padding:", spacing.small, ";z-index:100;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":"AAyD4B","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
46
46
  var NotionHeader = /*#__PURE__*/_styled("div", {
47
- target: "eqcj3r3",
47
+ target: "eqcj3r4",
48
48
  label: "NotionHeader"
49
- })("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":"AAyF+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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
49
+ })("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":"AA0F+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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
50
50
  var ListWrapper = /*#__PURE__*/_styled("div", {
51
- target: "eqcj3r2",
51
+ target: "eqcj3r3",
52
52
  label: "ListWrapper"
53
- })("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":"AA8G8B","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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
53
+ })("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":"AA+G8B","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
54
54
  var StyledNotionDialogContent = /*#__PURE__*/_styled(NotionDialogContent, {
55
- target: "eqcj3r1",
55
+ target: "eqcj3r2",
56
56
  label: "StyledNotionDialogContent"
57
- })("padding-top:", spacing.small, ";.c-figure{left:unset!important;width:100%!important;padding:0;margin:0;padding-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoH6D","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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
57
+ })("padding-top:", spacing.small, ";.c-figure{left:unset!important;width:100%!important;padding:0;margin:0;padding-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqH6D","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
58
+ var ButtonWrapper = /*#__PURE__*/_styled("div", {
59
+ target: "eqcj3r1",
60
+ label: "ButtonWrapper"
61
+ })("display:flex;gap:", spacing.xsmall, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAgIgC","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
58
62
  var StyledList = /*#__PURE__*/_styled("ul", {
59
63
  target: "eqcj3r0",
60
64
  label: "StyledList"
61
- })("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":"AA+H4B","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 } from 'react';\nimport { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
65
+ })("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":"AAsI4B","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 } from 'react';\nimport { ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData['concept']['conceptType'];\n  glossData?: ConceptData['concept']['glossData'];\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  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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  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: 100;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\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 ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\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      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'brightcove' ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === 'h5p' ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'iframe' ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === 'external' ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n              </StyledNotionDialogContent>\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          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === 'success' && visualElement.resource === 'audio'\n                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
62
66
  export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
63
67
  var _copyright$license;
64
68
  var visualElement = _ref.visualElement,
@@ -75,6 +79,7 @@ export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
75
79
  conceptHeartButton = _ref.conceptHeartButton,
76
80
  conceptType = _ref.conceptType,
77
81
  glossData = _ref.glossData,
82
+ headerButtons = _ref.headerButtons,
78
83
  rest = _objectWithoutProperties(_ref, _excluded);
79
84
  var _useTranslation = useTranslation(),
80
85
  t = _useTranslation.t;
@@ -88,7 +93,9 @@ export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
88
93
  children: [title.title, " ", _jsx("small", {
89
94
  children: t("searchPage.resultType.".concat(conceptType))
90
95
  })]
91
- }), closeButton]
96
+ }), _jsxs(ButtonWrapper, {
97
+ children: [headerButtons, closeButton]
98
+ })]
92
99
  }), conceptType !== 'gloss' ? _jsxs(_Fragment, {
93
100
  children: [_jsxs(StyledNotionDialogContent, {
94
101
  children: [(visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'image' ? _jsx(ImageEmbed, {
package/es/Embed/index.js CHANGED
@@ -18,4 +18,5 @@ export { default as RelatedContentEmbed } from './RelatedContentEmbed';
18
18
  export { default as ConceptEmbed } from './ConceptEmbed';
19
19
  export { ConceptNotionV2 } from './conceptComponents';
20
20
  export { default as ConceptListEmbed } from './ConceptListEmbed';
21
- export { default as UnknownEmbed } from './UnknownEmbed';
21
+ export { default as UnknownEmbed } from './UnknownEmbed';
22
+ export { InlineConcept } from './ConceptEmbed';