@ndla/ui 50.10.0 → 50.10.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -20,7 +20,7 @@ const StyledFigCaption = /*#__PURE__*/_styled("figcaption", {
20
20
  } : {
21
21
  name: "1oo694u",
22
22
  styles: "background:unset;font-size:unset;padding:unset;color:unset",
23
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlyaWdodEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBDIiwiZmlsZSI6IkNvcHlyaWdodEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENvcHlyaWdodE1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBFbWJlZEJ5bGluZSB9IGZyb20gXCIuLi9MaWNlbnNlQnlsaW5lXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBDb3B5cmlnaHRNZXRhRGF0YTtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFN0eWxlZEZpZ0NhcHRpb24gPSBzdHlsZWQuZmlnY2FwdGlvbmBcbiAgYmFja2dyb3VuZDogdW5zZXQ7XG4gIGZvbnQtc2l6ZTogdW5zZXQ7XG4gIHBhZGRpbmc6IHVuc2V0O1xuICBjb2xvcjogdW5zZXQ7XG5gO1xuXG5jb25zdCBDb3B5cmlnaHRFbWJlZCA9ICh7IGVtYmVkLCBjaGlsZHJlbiB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxmaWd1cmU+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkRmlnQ2FwdGlvbj5cbiAgICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJjb3B5cmlnaHRcIiBjb3B5cmlnaHQ9e2VtYmVkLmVtYmVkRGF0YS5jb3B5cmlnaHR9IGJvdHRvbVJvdW5kZWQgLz5cbiAgICAgIDwvU3R5bGVkRmlnQ2FwdGlvbj5cbiAgICA8L2ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlyaWdodEVtYmVkO1xuIl19 */",
23
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlyaWdodEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBDIiwiZmlsZSI6IkNvcHlyaWdodEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENvcHlyaWdodE1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBFbWJlZEJ5bGluZSB9IGZyb20gXCIuLi9MaWNlbnNlQnlsaW5lXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBDb3B5cmlnaHRNZXRhRGF0YTtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFN0eWxlZEZpZ0NhcHRpb24gPSBzdHlsZWQuZmlnY2FwdGlvbmBcbiAgYmFja2dyb3VuZDogdW5zZXQ7XG4gIGZvbnQtc2l6ZTogdW5zZXQ7XG4gIHBhZGRpbmc6IHVuc2V0O1xuICBjb2xvcjogdW5zZXQ7XG5gO1xuXG5jb25zdCBDb3B5cmlnaHRFbWJlZCA9ICh7IGVtYmVkLCBjaGlsZHJlbiB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxmaWd1cmU+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkRmlnQ2FwdGlvbiBjb250ZW50RWRpdGFibGU9e2ZhbHNlfT5cbiAgICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJjb3B5cmlnaHRcIiBjb3B5cmlnaHQ9e2VtYmVkLmVtYmVkRGF0YS5jb3B5cmlnaHR9IGJvdHRvbVJvdW5kZWQgLz5cbiAgICAgIDwvU3R5bGVkRmlnQ2FwdGlvbj5cbiAgICA8L2ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlyaWdodEVtYmVkO1xuIl19 */",
24
24
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
25
25
  });
26
26
  const CopyrightEmbed = _ref => {
@@ -30,6 +30,7 @@ const CopyrightEmbed = _ref => {
30
30
  } = _ref;
31
31
  return _jsxs("figure", {
32
32
  children: [children, _jsx(StyledFigCaption, {
33
+ contentEditable: false,
33
34
  children: _jsx(EmbedByline, {
34
35
  type: "copyright",
35
36
  copyright: embed.embedData.copyright,
@@ -24,42 +24,42 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
24
24
  const NotionDialogText = /*#__PURE__*/_styled("div", {
25
25
  target: "eqcj3r7",
26
26
  label: "NotionDialogText"
27
- })("font-weight:", fonts.weight.normal, ";", fonts.sizes("18px", 1.3), ";color:", colors.text.primary, ";font-family:", fonts.sans, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsDmC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
27
+ })("font-weight:", fonts.weight.normal, ";", fonts.sizes("18px", 1.3), ";color:", colors.text.primary, ";font-family:", fonts.sans, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsDmC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
28
28
  const NotionDialogContent = /*#__PURE__*/_styled("div", {
29
29
  target: "eqcj3r6",
30
30
  label: "NotionDialogContent"
31
- })("padding-bottom:", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA6DsC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
31
+ })("padding-bottom:", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA6DsC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
32
32
  const ContentSpacing = /*#__PURE__*/_styled("div", {
33
33
  target: "eqcj3r5",
34
34
  label: "ContentSpacing"
35
- })("padding:", spacing.normal, ";&[data-is-concept=\"false\"]{margin-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmEiC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
35
+ })("padding:", spacing.normal, ";&[data-is-concept=\"false\"]{margin-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmEiC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
36
36
  const 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:", stackOrder.offsetSingle, ";box-shadow:0 0 30px rgba(0, 0, 0, 0.2);", mq.range({
37
37
  from: breakpoints.tablet
38
38
  }), "{width:500px;}", mq.range({
39
39
  from: breakpoints.desktop
40
40
  }), "{width:720px;}", mq.range({
41
41
  until: breakpoints.tablet
42
- }), "{padding:", spacing.small, ";z-index:", stackOrder.popover, ";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":"AA0E4B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
42
+ }), "{padding:", spacing.small, ";z-index:", stackOrder.popover, ";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":"AA0E4B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
43
43
  const NotionHeader = /*#__PURE__*/_styled("div", {
44
44
  target: "eqcj3r4",
45
45
  label: "NotionHeader"
46
- })("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{", fonts.sizes("20px", 1.2), ";font-weight:", fonts.weight.normal, ";&[data-is-concept=\"true\"]{border-left:1px solid ", colors.brand.greyLight, ";padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";}}&[data-is-concept=\"false\"]{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2G+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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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
+ })("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{", fonts.sizes("20px", 1.2), ";font-weight:", fonts.weight.normal, ";&[data-is-concept=\"true\"]{border-left:1px solid ", colors.brand.greyLight, ";padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";}}&[data-is-concept=\"false\"]{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2G+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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
47
47
  const ListWrapper = /*#__PURE__*/_styled("div", {
48
48
  target: "eqcj3r3",
49
49
  label: "ListWrapper"
50
- })("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":"AAqI8B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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
+ })("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":"AAqI8B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
51
51
  const StyledNotionDialogContent = /*#__PURE__*/_styled(NotionDialogContent, {
52
52
  target: "eqcj3r2",
53
53
  label: "StyledNotionDialogContent"
54
- })("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":"AA2I6D","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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
+ })("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":"AA2I6D","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
55
55
  const ButtonWrapper = /*#__PURE__*/_styled("div", {
56
56
  target: "eqcj3r1",
57
57
  label: "ButtonWrapper"
58
- })("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":"AAsJgC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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
+ })("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":"AAsJgC","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
59
59
  const StyledList = /*#__PURE__*/_styled("ul", {
60
60
  target: "eqcj3r0",
61
61
  label: "StyledList"
62
- })("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{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":"AA4J4B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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
+ })("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{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":"AA4J4B","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 { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\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  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\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  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\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: ${stackOrder.popover};\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    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\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    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      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\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                {content && <NotionDialogText lang={lang}>{content}</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                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\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"]} */"));
63
63
  export const ConceptNotionV2 = /*#__PURE__*/forwardRef((_ref, ref) => {
64
64
  let {
65
65
  visualElement,
@@ -13,7 +13,7 @@ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
13
13
  const StyledFramedContent = /*#__PURE__*/_styled("div", {
14
14
  target: "eg9ts460",
15
15
  label: "StyledFramedContent"
16
- })("padding:", spacing.mediumlarge, ";margin:", spacing.large, " 0;border:1px solid ", colors.brand.tertiary, ";overflow:hidden;.c-figure{width:100%!important;left:auto!important;padding:0;&.u-float-right,&.u-float-small-right{width:50%!important;margin-right:0;}&.u-float-left,&.u-float-small-left{width:50%!important;margin-left:0;}}&:first-child{margin-top:0;}&:last-child{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyYW1lZENvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlzQyIsImZpbGUiOiJGcmFtZWRDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50UHJvcHNXaXRoUmVmLCBmb3J3YXJkUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZEZyYW1lZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcubWVkaXVtbGFyZ2V9O1xuICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMDtcbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuXG4gIC5jLWZpZ3VyZSB7XG4gICAgd2lkdGg6IDEwMCUgIWltcG9ydGFudDtcbiAgICBsZWZ0OiBhdXRvICFpbXBvcnRhbnQ7XG4gICAgcGFkZGluZzogMDtcblxuICAgICYudS1mbG9hdC1yaWdodCxcbiAgICAmLnUtZmxvYXQtc21hbGwtcmlnaHQge1xuICAgICAgd2lkdGg6IDUwJSAhaW1wb3J0YW50O1xuICAgICAgbWFyZ2luLXJpZ2h0OiAwO1xuICAgIH1cblxuICAgICYudS1mbG9hdC1sZWZ0LFxuICAgICYudS1mbG9hdC1zbWFsbC1sZWZ0IHtcbiAgICAgIHdpZHRoOiA1MCUgIWltcG9ydGFudDtcbiAgICAgIG1hcmdpbi1sZWZ0OiAwO1xuICAgIH1cbiAgfVxuXG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIG1hcmdpbi10b3A6IDA7XG4gIH1cblxuICAmOmxhc3QtY2hpbGQge1xuICAgIG1hcmdpbi1ib3R0b206IDA7XG4gIH1cbmA7XG5cbmNvbnN0IEZyYW1lZENvbnRlbnQgPSBmb3J3YXJkUmVmPEhUTUxEaXZFbGVtZW50LCBDb21wb25lbnRQcm9wc1dpdGhSZWY8XCJkaXZcIj4+KCh7IGNoaWxkcmVuLCAuLi5yZXN0IH0sIHJlZikgPT4gKFxuICA8U3R5bGVkRnJhbWVkQ29udGVudCB7Li4ucmVzdH0gcmVmPXtyZWZ9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9TdHlsZWRGcmFtZWRDb250ZW50PlxuKSk7XG5cbmV4cG9ydCBkZWZhdWx0IEZyYW1lZENvbnRlbnQ7XG4iXX0= */"));
16
+ })("padding:", spacing.mediumlarge, ";margin:", spacing.large, " 0;border:1px solid ", colors.brand.tertiary, ";overflow:hidden;.c-figure{width:100%!important;left:auto!important;padding:0;&.u-float-right,&.u-float-small-right{width:50%!important;margin-right:0;}&.u-float-left,&.u-float-small-left{width:50%!important;margin-left:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyYW1lZENvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlzQyIsImZpbGUiOiJGcmFtZWRDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50UHJvcHNXaXRoUmVmLCBmb3J3YXJkUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZEZyYW1lZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcubWVkaXVtbGFyZ2V9O1xuICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMDtcbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuXG4gIC5jLWZpZ3VyZSB7XG4gICAgd2lkdGg6IDEwMCUgIWltcG9ydGFudDtcbiAgICBsZWZ0OiBhdXRvICFpbXBvcnRhbnQ7XG4gICAgcGFkZGluZzogMDtcblxuICAgICYudS1mbG9hdC1yaWdodCxcbiAgICAmLnUtZmxvYXQtc21hbGwtcmlnaHQge1xuICAgICAgd2lkdGg6IDUwJSAhaW1wb3J0YW50O1xuICAgICAgbWFyZ2luLXJpZ2h0OiAwO1xuICAgIH1cblxuICAgICYudS1mbG9hdC1sZWZ0LFxuICAgICYudS1mbG9hdC1zbWFsbC1sZWZ0IHtcbiAgICAgIHdpZHRoOiA1MCUgIWltcG9ydGFudDtcbiAgICAgIG1hcmdpbi1sZWZ0OiAwO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRnJhbWVkQ29udGVudCA9IGZvcndhcmRSZWY8SFRNTERpdkVsZW1lbnQsIENvbXBvbmVudFByb3BzV2l0aFJlZjxcImRpdlwiPj4oKHsgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiAoXG4gIDxTdHlsZWRGcmFtZWRDb250ZW50IHsuLi5yZXN0fSByZWY9e3JlZn0+XG4gICAge2NoaWxkcmVufVxuICA8L1N0eWxlZEZyYW1lZENvbnRlbnQ+XG4pKTtcblxuZXhwb3J0IGRlZmF1bHQgRnJhbWVkQ29udGVudDtcbiJdfQ== */"));
17
17
  const FramedContent = /*#__PURE__*/forwardRef((_ref, ref) => {
18
18
  let {
19
19
  children,
@@ -18,7 +18,7 @@ export const LayoutItem = _ref => {
18
18
  if (layout === "extend") {
19
19
  return "u-10/12@desktop u-push-1/12@desktop u-10/12@tablet u-push-1/12@tablet";
20
20
  } else if (layout === "center") {
21
- return "u-7/10@desktop u-push-3/20@desktop u-10/12@tablet u-push-1/12@tablet";
21
+ return "u-10/12 u-push-1/12";
22
22
  }
23
23
  return undefined;
24
24
  }, [layout]);
@@ -13,7 +13,7 @@ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
13
13
  const StyledUl = /*#__PURE__*/_styled("ul", {
14
14
  target: "engrneb0",
15
15
  label: "StyledUl"
16
- })("padding-left:", spacing.nsmall, ";margin-left:", spacing.normal, ";", fonts.sizes("18px", "29px"), ";ul{margin-left:0;}>li{::marker{color:", colors.brand.secondary, ";}}li{padding-top:0;padding-left:", spacing.nsmall, ";margin-top:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlVuT3JkZXJlZExpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVkwQiIsImZpbGUiOiJVbk9yZGVyZWRMaXN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZFVsID0gc3R5bGVkLnVsYFxuICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5uc21hbGx9O1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7Zm9udHMuc2l6ZXMoXCIxOHB4XCIsIFwiMjlweFwiKX07XG5cbiAgdWwge1xuICAgIG1hcmdpbi1sZWZ0OiAwO1xuICB9XG5cbiAgPiBsaSB7XG4gICAgOjptYXJrZXIge1xuICAgICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLnNlY29uZGFyeX07XG4gICAgfVxuICB9XG4gIC8vIExpc3QgaXRlbVxuICBsaSB7XG4gICAgcGFkZGluZy10b3A6IDA7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcubnNtYWxsfTtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcubnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgVW5PcmRlcmVkTGlzdCA9IGZvcndhcmRSZWY8SFRNTFVMaXN0RWxlbWVudCwgSFRNTEF0dHJpYnV0ZXM8SFRNTFVMaXN0RWxlbWVudD4+KCh7IGNoaWxkcmVuLCAuLi5yZXN0IH0sIHJlZikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRVbCByZWY9e3JlZn0gey4uLnJlc3R9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkVWw+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVW5PcmRlcmVkTGlzdDtcbiJdfQ== */"));
16
+ })("padding-left:", spacing.nsmall, ";margin:", spacing.normal, " 0 ", spacing.normal, " ", spacing.normal, ";", fonts.size.text.content, ";ul{margin:0;}>li{::marker{color:", colors.brand.secondary, ";}}li{padding-top:0;padding-left:", spacing.nsmall, ";margin-top:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlVuT3JkZXJlZExpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVkwQiIsImZpbGUiOiJVbk9yZGVyZWRMaXN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZFVsID0gc3R5bGVkLnVsYFxuICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5uc21hbGx9O1xuICBtYXJnaW46ICR7c3BhY2luZy5ub3JtYWx9IDAgJHtzcGFjaW5nLm5vcm1hbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7Zm9udHMuc2l6ZS50ZXh0LmNvbnRlbnR9O1xuXG4gIHVsIHtcbiAgICBtYXJnaW46IDA7XG4gIH1cblxuICA+IGxpIHtcbiAgICA6Om1hcmtlciB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuc2Vjb25kYXJ5fTtcbiAgICB9XG4gIH1cbiAgLy8gTGlzdCBpdGVtXG4gIGxpIHtcbiAgICBwYWRkaW5nLXRvcDogMDtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5uc21hbGx9O1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5uc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBVbk9yZGVyZWRMaXN0ID0gZm9yd2FyZFJlZjxIVE1MVUxpc3RFbGVtZW50LCBIVE1MQXR0cmlidXRlczxIVE1MVUxpc3RFbGVtZW50Pj4oKHsgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFVsIHJlZj17cmVmfSB7Li4ucmVzdH0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRVbD5cbiAgKTtcbn0pO1xuXG5leHBvcnQgZGVmYXVsdCBVbk9yZGVyZWRMaXN0O1xuIl19 */"));
17
17
  const UnOrderedList = /*#__PURE__*/forwardRef((_ref, ref) => {
18
18
  let {
19
19
  children,