@ndla/ui 34.6.2 → 34.6.4

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.
Files changed (153) hide show
  1. package/es/Article/Article.js +11 -6
  2. package/es/Aside/Aside.js +5 -2
  3. package/es/CopyParagraphButton/CopyParagraphButtonV2.js +85 -0
  4. package/es/CopyParagraphButton/index.js +2 -1
  5. package/es/Embed/AudioEmbed.js +254 -0
  6. package/es/Embed/BrightcoveEmbed.js +250 -0
  7. package/es/Embed/ConceptEmbed.js +359 -0
  8. package/es/Embed/ConceptListEmbed.js +71 -0
  9. package/es/Embed/ContentLinkEmbed.js +42 -0
  10. package/es/Embed/ExternalEmbed.js +91 -0
  11. package/es/Embed/FootnoteEmbed.js +32 -0
  12. package/es/Embed/H5pEmbed.js +87 -0
  13. package/es/Embed/IframeEmbed.js +83 -0
  14. package/es/Embed/ImageEmbed.js +322 -0
  15. package/es/Embed/RelatedContentEmbed.js +58 -0
  16. package/es/Embed/UnknownEmbed.js +27 -0
  17. package/es/Embed/conceptComponents.js +282 -0
  18. package/es/Embed/index.js +21 -0
  19. package/es/FactBox/FactBoxV2.js +90 -0
  20. package/es/FactBox/index.js +1 -0
  21. package/es/Figure/Figure.js +8 -5
  22. package/es/Figure/FigureLicenseDialogContent.js +72 -0
  23. package/es/FileList/FileListV2.js +47 -0
  24. package/es/FileList/FileV2.js +34 -0
  25. package/es/FileList/PdfFile.js +25 -0
  26. package/es/FileList/index.js +3 -0
  27. package/es/Notion/Notion.js +5 -5
  28. package/es/Notion/NotionVisualElement.js +2 -2
  29. package/es/RelatedArticleList/RelatedArticleV2.js +101 -0
  30. package/es/RelatedArticleList/index.js +2 -1
  31. package/es/Table/Table.js +95 -8
  32. package/es/all.css +1 -1
  33. package/es/index.js +5 -4
  34. package/es/locale/messages-en.js +32 -2
  35. package/es/locale/messages-nb.js +32 -2
  36. package/es/locale/messages-nn.js +32 -2
  37. package/es/locale/messages-se.js +32 -2
  38. package/es/locale/messages-sma.js +32 -2
  39. package/lib/Article/Article.d.ts +2 -1
  40. package/lib/Article/Article.js +11 -6
  41. package/lib/Aside/Aside.d.ts +2 -1
  42. package/lib/Aside/Aside.js +5 -2
  43. package/lib/CopyParagraphButton/CopyParagraphButtonV2.d.ts +14 -0
  44. package/lib/CopyParagraphButton/CopyParagraphButtonV2.js +84 -0
  45. package/lib/CopyParagraphButton/index.d.ts +2 -1
  46. package/lib/CopyParagraphButton/index.js +7 -0
  47. package/lib/Embed/AudioEmbed.d.ts +20 -0
  48. package/lib/Embed/AudioEmbed.js +252 -0
  49. package/lib/Embed/BrightcoveEmbed.d.ts +16 -0
  50. package/lib/Embed/BrightcoveEmbed.js +250 -0
  51. package/lib/Embed/ConceptEmbed.d.ts +19 -0
  52. package/lib/Embed/ConceptEmbed.js +359 -0
  53. package/lib/Embed/ConceptListEmbed.d.ts +13 -0
  54. package/lib/Embed/ConceptListEmbed.js +70 -0
  55. package/lib/Embed/ContentLinkEmbed.d.ts +14 -0
  56. package/lib/Embed/ContentLinkEmbed.js +50 -0
  57. package/lib/Embed/ExternalEmbed.d.ts +14 -0
  58. package/lib/Embed/ExternalEmbed.js +90 -0
  59. package/lib/Embed/FootnoteEmbed.d.ts +13 -0
  60. package/lib/Embed/FootnoteEmbed.js +39 -0
  61. package/lib/Embed/H5pEmbed.d.ts +14 -0
  62. package/lib/Embed/H5pEmbed.js +86 -0
  63. package/lib/Embed/IframeEmbed.d.ts +14 -0
  64. package/lib/Embed/IframeEmbed.js +91 -0
  65. package/lib/Embed/ImageEmbed.d.ts +37 -0
  66. package/lib/Embed/ImageEmbed.js +326 -0
  67. package/lib/Embed/RelatedContentEmbed.d.ts +16 -0
  68. package/lib/Embed/RelatedContentEmbed.js +64 -0
  69. package/lib/Embed/UnknownEmbed.d.ts +13 -0
  70. package/lib/Embed/UnknownEmbed.js +35 -0
  71. package/lib/Embed/conceptComponents.d.ts +32 -0
  72. package/lib/Embed/conceptComponents.js +280 -0
  73. package/lib/Embed/index.d.ts +20 -0
  74. package/lib/Embed/index.js +97 -0
  75. package/lib/FactBox/FactBoxV2.d.ts +13 -0
  76. package/lib/FactBox/FactBoxV2.js +92 -0
  77. package/lib/FactBox/index.d.ts +1 -0
  78. package/lib/FactBox/index.js +7 -0
  79. package/lib/Figure/Figure.d.ts +5 -2
  80. package/lib/Figure/Figure.js +8 -5
  81. package/lib/Figure/FigureLicenseDialogContent.d.ts +22 -0
  82. package/lib/Figure/FigureLicenseDialogContent.js +71 -0
  83. package/lib/FileList/FileListV2.d.ts +13 -0
  84. package/lib/FileList/FileListV2.js +46 -0
  85. package/lib/FileList/FileV2.d.ts +16 -0
  86. package/lib/FileList/FileV2.js +42 -0
  87. package/lib/FileList/PdfFile.d.ts +13 -0
  88. package/lib/FileList/PdfFile.js +31 -0
  89. package/lib/FileList/index.d.ts +3 -0
  90. package/lib/FileList/index.js +21 -0
  91. package/lib/Notion/Notion.js +5 -5
  92. package/lib/Notion/NotionVisualElement.d.ts +1 -1
  93. package/lib/Notion/NotionVisualElement.js +2 -2
  94. package/lib/RelatedArticleList/RelatedArticleV2.d.ts +25 -0
  95. package/lib/RelatedArticleList/RelatedArticleV2.js +101 -0
  96. package/lib/RelatedArticleList/index.d.ts +2 -1
  97. package/lib/RelatedArticleList/index.js +7 -0
  98. package/lib/Table/Table.js +98 -8
  99. package/lib/all.css +1 -1
  100. package/lib/index.d.ts +5 -4
  101. package/lib/index.js +117 -2
  102. package/lib/locale/messages-en.d.ts +30 -0
  103. package/lib/locale/messages-en.js +32 -2
  104. package/lib/locale/messages-nb.d.ts +30 -0
  105. package/lib/locale/messages-nb.js +32 -2
  106. package/lib/locale/messages-nn.d.ts +30 -0
  107. package/lib/locale/messages-nn.js +32 -2
  108. package/lib/locale/messages-se.d.ts +30 -0
  109. package/lib/locale/messages-se.js +32 -2
  110. package/lib/locale/messages-sma.d.ts +30 -0
  111. package/lib/locale/messages-sma.js +32 -2
  112. package/lib/types.d.ts +1 -1
  113. package/package.json +16 -12
  114. package/src/Article/Article.tsx +8 -3
  115. package/src/Aside/Aside.tsx +9 -1
  116. package/src/Aside/component.aside.scss +3 -0
  117. package/src/CopyParagraphButton/CopyParagraphButtonV2.tsx +84 -0
  118. package/src/CopyParagraphButton/index.tsx +2 -1
  119. package/src/Embed/AudioEmbed.tsx +249 -0
  120. package/src/Embed/BrightcoveEmbed.tsx +203 -0
  121. package/src/Embed/ConceptEmbed.tsx +403 -0
  122. package/src/Embed/ConceptListEmbed.tsx +64 -0
  123. package/src/Embed/ContentLinkEmbed.tsx +41 -0
  124. package/src/Embed/ExternalEmbed.tsx +80 -0
  125. package/src/Embed/FootnoteEmbed.tsx +30 -0
  126. package/src/Embed/H5pEmbed.tsx +74 -0
  127. package/src/Embed/IframeEmbed.tsx +84 -0
  128. package/src/Embed/ImageEmbed.tsx +314 -0
  129. package/src/Embed/RelatedContentEmbed.tsx +62 -0
  130. package/src/Embed/UnknownEmbed.tsx +27 -0
  131. package/src/Embed/conceptComponents.tsx +393 -0
  132. package/src/Embed/index.ts +21 -0
  133. package/src/FactBox/FactBoxV2.tsx +56 -0
  134. package/src/FactBox/index.ts +2 -0
  135. package/src/Figure/Figure.tsx +28 -15
  136. package/src/Figure/FigureLicenseDialogContent.tsx +80 -0
  137. package/src/Figure/component.figure.scss +0 -1
  138. package/src/FileList/FileListV2.tsx +58 -0
  139. package/src/FileList/FileV2.tsx +35 -0
  140. package/src/FileList/PdfFile.tsx +25 -0
  141. package/src/FileList/index.ts +3 -0
  142. package/src/Notion/Notion.tsx +0 -1
  143. package/src/Notion/NotionVisualElement.tsx +1 -1
  144. package/src/RelatedArticleList/RelatedArticleV2.tsx +84 -0
  145. package/src/RelatedArticleList/index.ts +2 -1
  146. package/src/Table/Table.tsx +77 -4
  147. package/src/index.ts +19 -4
  148. package/src/locale/messages-en.ts +33 -0
  149. package/src/locale/messages-nb.ts +33 -0
  150. package/src/locale/messages-nn.ts +33 -0
  151. package/src/locale/messages-se.ts +33 -0
  152. package/src/locale/messages-sma.ts +33 -0
  153. package/src/types.ts +1 -1
@@ -0,0 +1,359 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = exports.ConceptEmbed = exports.BlockConcept = void 0;
7
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
+ var _react = require("react");
9
+ var _reactI18next = require("react-i18next");
10
+ var _reactDeviceDetect = require("react-device-detect");
11
+ var _reactPopover = require("@radix-ui/react-popover");
12
+ var _button = require("@ndla/button");
13
+ var _action = require("@ndla/icons/action");
14
+ var _core = require("@ndla/core");
15
+ var _licenses = require("@ndla/licenses");
16
+ var _modal = require("@ndla/modal");
17
+ var _tooltip = _interopRequireDefault(require("@ndla/tooltip"));
18
+ var _Notion = require("../Notion");
19
+ var _Figure = require("../Figure");
20
+ var _FigureLicenseDialogContent = require("../Figure/FigureLicenseDialogContent");
21
+ var _NotionImage = require("../Notion/NotionImage");
22
+ var _conceptComponents = require("./conceptComponents");
23
+ var _jsxRuntime = require("@emotion/react/jsx-runtime");
24
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
25
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
26
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
27
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
28
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
29
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
30
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
31
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
32
+ var BottomBorder = /*#__PURE__*/(0, _base["default"])("div", {
33
+ target: "e6acljj7",
34
+ label: "BottomBorder"
35
+ })("margin-top:", _core.spacing.normal, ";border-bottom:1px solid ", _core.colors.brand.greyLight, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AA0B+B","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
36
+ var PopoverWrapper = /*#__PURE__*/(0, _base["default"])("div", {
37
+ target: "e6acljj6",
38
+ label: "PopoverWrapper"
39
+ })("div[data-radix-popper-content-wrapper]{position:absolute!important;left:50%!important;transform:translateX(-50%)!important;top:", function (_ref) {
40
+ var top = _ref.top;
41
+ return top;
42
+ }, "px!important;}", _core.mq.range({
43
+ until: _core.breakpoints.tablet
44
+ }), "{div[data-radix-popper-content-wrapper]{position:fixed!important;transform:none!important;top:0!important;left:0!important;width:100vw;z-index:9999!important;height:100vh;min-width:100vw!important;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AAmCkD","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
45
+ var ImageWrapper = /*#__PURE__*/(0, _base["default"])("div", {
46
+ target: "e6acljj5",
47
+ label: "ImageWrapper"
48
+ })("float:right;padding-left:", _core.spacing.normal, ";position:relative;", _core.mq.range({
49
+ until: _core.breakpoints.tabletWide
50
+ }), "{width:100%;padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AA4D+B","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
51
+ var StyledButton = /*#__PURE__*/(0, _base["default"])("button", {
52
+ target: "e6acljj4",
53
+ label: "StyledButton"
54
+ })("background:none;border:none;font-family:inherit;font-style:inherit;line-height:1em;padding:0 0 4px 0;margin-bottom:-4px;text-decoration:none;color:#000;position:relative;cursor:pointer;&:focus,&:hover{color:", _core.colors.brand.primary, ";outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AA4EkC","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
55
+ var ConceptEmbed = function ConceptEmbed(_ref2) {
56
+ var embed = _ref2.embed,
57
+ fullWidth = _ref2.fullWidth;
58
+ if (embed.status === 'error') {
59
+ return (0, _jsxRuntime.jsx)("span", {
60
+ children: embed.embedData.linkText
61
+ });
62
+ }
63
+ var _embed$data = embed.data,
64
+ concept = _embed$data.concept,
65
+ visualElement = _embed$data.visualElement;
66
+ if (embed.embedData.type === 'block') {
67
+ var _concept$content;
68
+ return (0, _jsxRuntime.jsx)(BlockConcept, {
69
+ fullWidth: fullWidth,
70
+ title: concept.title.title,
71
+ content: (_concept$content = concept.content) === null || _concept$content === void 0 ? void 0 : _concept$content.content,
72
+ metaImage: concept.metaImage,
73
+ copyright: concept.copyright,
74
+ source: concept.source,
75
+ visualElement: visualElement
76
+ });
77
+ } else if (embed.embedData.type === 'inline') {
78
+ var _concept$content2;
79
+ return (0, _jsxRuntime.jsx)(InlineConcept, {
80
+ title: concept.title.title,
81
+ content: (_concept$content2 = concept.content) === null || _concept$content2 === void 0 ? void 0 : _concept$content2.content,
82
+ metaImage: concept.metaImage,
83
+ copyright: concept.copyright,
84
+ source: concept.source,
85
+ visualElement: visualElement,
86
+ linkText: embed.embedData.linkText
87
+ });
88
+ } else {
89
+ var _concept$content3;
90
+ return (0, _jsxRuntime.jsx)(_conceptComponents.ConceptNotionV2, {
91
+ title: concept.title.title,
92
+ content: (_concept$content3 = concept.content) === null || _concept$content3 === void 0 ? void 0 : _concept$content3.content,
93
+ metaImage: concept.metaImage,
94
+ copyright: concept.copyright,
95
+ source: concept.source,
96
+ visualElement: visualElement
97
+ });
98
+ }
99
+ };
100
+ exports.ConceptEmbed = ConceptEmbed;
101
+ var BaselineIcon = /*#__PURE__*/(0, _base["default"])("span", {
102
+ target: "e6acljj3",
103
+ label: "BaselineIcon"
104
+ })(process.env.NODE_ENV === "production" ? {
105
+ name: "6mki3j",
106
+ styles: "display:block;border-bottom:5px double currentColor"
107
+ } : {
108
+ name: "6mki3j",
109
+ styles: "display:block;border-bottom:5px double currentColor",
110
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AAkJgC","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */",
111
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
112
+ });
113
+ var NotionButton = /*#__PURE__*/(0, _base["default"])("button", {
114
+ target: "e6acljj2",
115
+ label: "NotionButton"
116
+ })("background:none;border:none;font-family:inherit;font-style:inherit;line-height:1em;padding:0 0 4px 0;margin-bottom:-4px;text-decoration:none;position:relative;text-align:left;display:inline;color:", _core.colors.notion.dark, ";cursor:pointer;&:focus,&:hover{background-color:", _core.colors.notion.dark, ";color:", _core.colors.white, ";outline:none;", BaselineIcon, "{border-color:transparent;}}&:active{color:", _core.colors.notion.dark, ";background-color:", _core.colors.notion.light, ";", BaselineIcon, "{border-color:currentColor;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AAuJkC","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
117
+ var StyledAnchor = /*#__PURE__*/(0, _base["default"])(_reactPopover.Anchor, {
118
+ target: "e6acljj1",
119
+ label: "StyledAnchor"
120
+ })(_core.mq.range({
121
+ until: _core.breakpoints.tablet
122
+ }), "{position:fixed;top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AAwLmC","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */"));
123
+ var StyledAnchorSpan = /*#__PURE__*/(0, _base["default"])("span", {
124
+ target: "e6acljj0",
125
+ label: "StyledAnchorSpan"
126
+ })(process.env.NODE_ENV === "production" ? {
127
+ name: "zcodsq",
128
+ styles: "position:absolute;left:50%;align-self:center"
129
+ } : {
130
+ name: "zcodsq",
131
+ styles: "position:absolute;left:50%;align-self:center",
132
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ConceptEmbed.tsx"],"names":[],"mappings":"AA+LoC","file":"ConceptEmbed.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 { useCallback, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { isMobile } from 'react-device-detect';\nimport { Root, Trigger, Content, Anchor, Close, Portal } from '@radix-ui/react-popover';\nimport { ButtonV2, IconButtonV2 } from '@ndla/button';\nimport { Cross } from '@ndla/icons/action';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { ModalV2 } from '@ndla/modal';\nimport { ConceptMetaData } from '@ndla/types-embed';\nimport Tooltip from '@ndla/tooltip';\nimport { Notion as UINotion } from '../Notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { NotionImage } from '../Notion/NotionImage';\nimport { ConceptNotionV2, ConceptNotionData } from './conceptComponents';\n\nconst BottomBorder = styled.div`\n  margin-top: ${spacing.normal};\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\ninterface PopoverPosition {\n  top?: number;\n}\n\nconst PopoverWrapper = styled.div<PopoverPosition>`\n  div[data-radix-popper-content-wrapper] {\n    position: absolute !important;\n    left: 50% !important;\n    transform: translateX(-50%) !important;\n    top: ${({ top }) => top}px !important;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    div[data-radix-popper-content-wrapper] {\n      // Fix for popover positioning on mobile.\n      // If we modify all popovers we break license icons.\n      // https://github.com/radix-ui/primitives/issues/1839\n      position: fixed !important;\n      transform: none !important;\n      top: 0 !important;\n      left: 0 !important;\n      width: 100vw;\n      z-index: 9999 !important;\n      height: 100vh;\n      min-width: 100vw !important;\n    }\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\ninterface Props {\n  embed: ConceptMetaData;\n  fullWidth?: boolean;\n}\n\nconst StyledButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  color: #000;\n  position: relative;\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    color: ${colors.brand.primary};\n    outline: none;\n  }\n`;\n\nexport const ConceptEmbed = ({ embed, fullWidth }: Props) => {\n  if (embed.status === 'error') {\n    return <span>{embed.embedData.linkText}</span>;\n  }\n\n  const {\n    data: { concept, visualElement },\n  } = embed;\n\n  if (embed.embedData.type === 'block') {\n    return (\n      <BlockConcept\n        fullWidth={fullWidth}\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  } else if (embed.embedData.type === 'inline') {\n    return (\n      <InlineConcept\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n        linkText={embed.embedData.linkText}\n      />\n    );\n  } else {\n    return (\n      <ConceptNotionV2\n        title={concept.title.title}\n        content={concept.content?.content}\n        metaImage={concept.metaImage}\n        copyright={concept.copyright}\n        source={concept.source}\n        visualElement={visualElement}\n      />\n    );\n  }\n};\n\ninterface InlineConceptProps extends ConceptNotionData {\n  linkText: string;\n}\n\nconst BaselineIcon = styled.span`\n  display: block;\n  border-bottom: 5px double currentColor;\n`;\n\nconst NotionButton = styled.button`\n  background: none;\n  border: none;\n  font-family: inherit;\n  font-style: inherit;\n  line-height: 1em;\n  padding: 0 0 4px 0;\n  margin-bottom: -4px;\n  text-decoration: none;\n  position: relative;\n  text-align: left;\n  display: inline;\n  color: ${colors.notion.dark};\n  cursor: pointer;\n  &:focus,\n  &:hover {\n    background-color: ${colors.notion.dark};\n    color: ${colors.white};\n    outline: none;\n    ${BaselineIcon} {\n      border-color: transparent;\n    }\n  }\n\n  &:active {\n    color: ${colors.notion.dark};\n    background-color: ${colors.notion.light};\n    ${BaselineIcon} {\n      border-color: currentColor;\n    }\n  }\n`;\n\nconst StyledAnchor = styled(Anchor)`\n  ${mq.range({ until: breakpoints.tablet })} {\n    position: fixed;\n    top: 0;\n  }\n`;\n\nconst StyledAnchorSpan = styled.span`\n  position: absolute;\n  left: 50%;\n  align-self: center;\n`;\n\nconst getModalPosition = (anchor: HTMLElement) => {\n  const article = anchor.closest('.c-article');\n  const articlePos = article?.getBoundingClientRect();\n  const anchorPos = anchor.getBoundingClientRect();\n  return anchorPos.top - (articlePos?.top || -window.scrollY);\n};\n\nconst InlineConcept = ({ title, content, copyright, source, visualElement, linkText }: InlineConceptProps) => {\n  const { t } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} asChild>\n        <StyledAnchorSpan />\n      </StyledAnchor>\n      <Trigger asChild>\n        <NotionButton>\n          {linkText}\n          {<BaselineIcon />}\n        </NotionButton>\n      </Trigger>\n      <Portal container={(anchorRef.current?.closest('.c-article') as HTMLElement | null) || undefined}>\n        <PopoverWrapper top={modalPos}>\n          <Content avoidCollisions={false} side=\"bottom\" asChild>\n            <ConceptNotionV2\n              title={title}\n              content={content}\n              copyright={copyright}\n              source={source}\n              visualElement={visualElement}\n              inPopover\n              closeButton={\n                <Close asChild>\n                  <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                    <Cross />\n                  </IconButtonV2>\n                </Close>\n              }\n            />\n          </Content>\n        </PopoverWrapper>\n      </Portal>\n    </Root>\n  );\n};\n\ninterface ConceptProps extends ConceptNotionData {\n  fullWidth?: boolean;\n}\n\nexport const BlockConcept = ({\n  title,\n  content,\n  metaImage,\n  copyright,\n  source,\n  visualElement,\n  fullWidth,\n}: ConceptProps) => {\n  const { t, i18n } = useTranslation();\n  const anchorRef = useRef<HTMLDivElement>(null);\n  const [modalPos, setModalPos] = useState(-9999);\n\n  const [isOpen, setIsOpen] = useState(false);\n  const licenseCredits = getLicenseCredits(copyright);\n  const { creators, rightsholders, processors } = licenseCredits;\n  const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n  const visualElementType =\n    visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n  const groupedAuthors = getGroupedContributorDescriptionList(licenseCredits, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n  const license = copyright?.license && getLicenseByAbbreviation(copyright?.license?.license, i18n.language);\n\n  const onOpenChange = useCallback((open: boolean) => {\n    if (open) {\n      const anchor = anchorRef.current;\n      if (anchor) {\n        const top = getModalPosition(anchor);\n        setModalPos(top);\n      }\n    } else {\n      setModalPos(-9999);\n    }\n  }, []);\n\n  return (\n    <Root modal={isMobile} onOpenChange={onOpenChange}>\n      <StyledAnchor ref={anchorRef} />\n      <Figure resizeIframe type={fullWidth ? 'full' : 'full-column'}>\n        <UINotion\n          id=\"\"\n          title={title}\n          text={content}\n          visualElement={\n            visualElement?.status === 'success' && (\n              <>\n                <ImageWrapper>\n                  <Tooltip tooltip={t('searchPage.resultType.showNotion')}>\n                    <Trigger asChild>\n                      <StyledButton type=\"button\" aria-label={t('concept.showDescription', { title: title })}>\n                        {visualElement.resource === 'image' ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={visualElement.data.imageUrl}\n                            alt={visualElement.data.alttext.alttext}\n                          />\n                        ) : metaImage ? (\n                          <NotionImage\n                            type={visualElementType}\n                            id={''}\n                            src={metaImage?.url ?? ''}\n                            alt={metaImage?.alt ?? ''}\n                          />\n                        ) : undefined}\n                      </StyledButton>\n                    </Trigger>\n                  </Tooltip>\n                </ImageWrapper>\n                <Portal\n                  container={\n                    typeof document !== 'undefined'\n                      ? (document.querySelector('.c-article') as HTMLElement | null) || undefined\n                      : undefined\n                  }>\n                  <PopoverWrapper top={modalPos}>\n                    <Content avoidCollisions={false} asChild side=\"bottom\">\n                      <ConceptNotionV2\n                        title={title}\n                        content={content}\n                        copyright={copyright}\n                        source={source}\n                        visualElement={visualElement}\n                        inPopover\n                        closeButton={\n                          <Close asChild>\n                            <IconButtonV2 aria-label={t('close')} variant=\"ghost\">\n                              <Cross />\n                            </IconButtonV2>\n                          </Close>\n                        }\n                      />\n                    </Content>\n                  </PopoverWrapper>\n                </Portal>\n              </>\n            )\n          }\n        />\n        {copyright?.license && license ? (\n          <FigureCaption\n            figureId=\"\"\n            id=\"\"\n            authors={authors}\n            licenseRights={license.rights}\n            locale={i18n.language}\n            hideIconsAndAuthors\n            modalButton={\n              <ButtonV2 variant=\"outline\" size=\"small\" shape=\"pill\" onClick={() => setIsOpen(true)}>\n                {t('concept.reuse')}\n              </ButtonV2>\n            }>\n            <ModalV2\n              controlled\n              isOpen={isOpen}\n              onClose={() => setIsOpen(false)}\n              labelledBy=\"license-dialog-rules-heading\">\n              {(close) => (\n                <FigureLicenseDialogContent\n                  authors={groupedAuthors}\n                  locale={i18n.language}\n                  title={title}\n                  origin={copyright.origin}\n                  license={license}\n                  onClose={close}\n                  type=\"concept\"\n                />\n              )}\n            </ModalV2>\n          </FigureCaption>\n        ) : (\n          <BottomBorder />\n        )}\n      </Figure>\n    </Root>\n  );\n};\n\nexport default ConceptEmbed;\n"]} */",
133
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
134
+ });
135
+ var getModalPosition = function getModalPosition(anchor) {
136
+ var article = anchor.closest('.c-article');
137
+ var articlePos = article === null || article === void 0 ? void 0 : article.getBoundingClientRect();
138
+ var anchorPos = anchor.getBoundingClientRect();
139
+ return anchorPos.top - ((articlePos === null || articlePos === void 0 ? void 0 : articlePos.top) || -window.scrollY);
140
+ };
141
+ var InlineConcept = function InlineConcept(_ref3) {
142
+ var _anchorRef$current;
143
+ var title = _ref3.title,
144
+ content = _ref3.content,
145
+ copyright = _ref3.copyright,
146
+ source = _ref3.source,
147
+ visualElement = _ref3.visualElement,
148
+ linkText = _ref3.linkText;
149
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
150
+ t = _useTranslation.t;
151
+ var anchorRef = (0, _react.useRef)(null);
152
+ var _useState = (0, _react.useState)(-9999),
153
+ _useState2 = _slicedToArray(_useState, 2),
154
+ modalPos = _useState2[0],
155
+ setModalPos = _useState2[1];
156
+ var onOpenChange = (0, _react.useCallback)(function (open) {
157
+ if (open) {
158
+ var anchor = anchorRef.current;
159
+ if (anchor) {
160
+ var top = getModalPosition(anchor);
161
+ setModalPos(top);
162
+ }
163
+ } else {
164
+ setModalPos(-9999);
165
+ }
166
+ }, []);
167
+ return (0, _jsxRuntime.jsxs)(_reactPopover.Root, {
168
+ modal: _reactDeviceDetect.isMobile,
169
+ onOpenChange: onOpenChange,
170
+ children: [(0, _jsxRuntime.jsx)(StyledAnchor, {
171
+ ref: anchorRef,
172
+ asChild: true,
173
+ children: (0, _jsxRuntime.jsx)(StyledAnchorSpan, {})
174
+ }), (0, _jsxRuntime.jsx)(_reactPopover.Trigger, {
175
+ asChild: true,
176
+ children: (0, _jsxRuntime.jsxs)(NotionButton, {
177
+ children: [linkText, (0, _jsxRuntime.jsx)(BaselineIcon, {})]
178
+ })
179
+ }), (0, _jsxRuntime.jsx)(_reactPopover.Portal, {
180
+ container: ((_anchorRef$current = anchorRef.current) === null || _anchorRef$current === void 0 ? void 0 : _anchorRef$current.closest('.c-article')) || undefined,
181
+ children: (0, _jsxRuntime.jsx)(PopoverWrapper, {
182
+ top: modalPos,
183
+ children: (0, _jsxRuntime.jsx)(_reactPopover.Content, {
184
+ avoidCollisions: false,
185
+ side: "bottom",
186
+ asChild: true,
187
+ children: (0, _jsxRuntime.jsx)(_conceptComponents.ConceptNotionV2, {
188
+ title: title,
189
+ content: content,
190
+ copyright: copyright,
191
+ source: source,
192
+ visualElement: visualElement,
193
+ inPopover: true,
194
+ closeButton: (0, _jsxRuntime.jsx)(_reactPopover.Close, {
195
+ asChild: true,
196
+ children: (0, _jsxRuntime.jsx)(_button.IconButtonV2, {
197
+ "aria-label": t('close'),
198
+ variant: "ghost",
199
+ children: (0, _jsxRuntime.jsx)(_action.Cross, {})
200
+ })
201
+ })
202
+ })
203
+ })
204
+ })
205
+ })]
206
+ });
207
+ };
208
+ var BlockConcept = function BlockConcept(_ref4) {
209
+ var _copyright$license, _metaImage$url, _metaImage$alt;
210
+ var title = _ref4.title,
211
+ content = _ref4.content,
212
+ metaImage = _ref4.metaImage,
213
+ copyright = _ref4.copyright,
214
+ source = _ref4.source,
215
+ visualElement = _ref4.visualElement,
216
+ fullWidth = _ref4.fullWidth;
217
+ var _useTranslation2 = (0, _reactI18next.useTranslation)(),
218
+ t = _useTranslation2.t,
219
+ i18n = _useTranslation2.i18n;
220
+ var anchorRef = (0, _react.useRef)(null);
221
+ var _useState3 = (0, _react.useState)(-9999),
222
+ _useState4 = _slicedToArray(_useState3, 2),
223
+ modalPos = _useState4[0],
224
+ setModalPos = _useState4[1];
225
+ var _useState5 = (0, _react.useState)(false),
226
+ _useState6 = _slicedToArray(_useState5, 2),
227
+ isOpen = _useState6[0],
228
+ setIsOpen = _useState6[1];
229
+ var licenseCredits = (0, _licenses.getLicenseCredits)(copyright);
230
+ var creators = licenseCredits.creators,
231
+ rightsholders = licenseCredits.rightsholders,
232
+ processors = licenseCredits.processors;
233
+ var authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;
234
+ var visualElementType = (visualElement === null || visualElement === void 0 ? void 0 : visualElement.embedData.resource) === 'brightcove' ? 'video' : visualElement === null || visualElement === void 0 ? void 0 : visualElement.embedData.resource;
235
+ var groupedAuthors = (0, _licenses.getGroupedContributorDescriptionList)(licenseCredits, i18n.language).map(function (item) {
236
+ return {
237
+ name: item.description,
238
+ type: item.label
239
+ };
240
+ });
241
+ var license = (copyright === null || copyright === void 0 ? void 0 : copyright.license) && (0, _licenses.getLicenseByAbbreviation)(copyright === null || copyright === void 0 ? void 0 : (_copyright$license = copyright.license) === null || _copyright$license === void 0 ? void 0 : _copyright$license.license, i18n.language);
242
+ var onOpenChange = (0, _react.useCallback)(function (open) {
243
+ if (open) {
244
+ var anchor = anchorRef.current;
245
+ if (anchor) {
246
+ var top = getModalPosition(anchor);
247
+ setModalPos(top);
248
+ }
249
+ } else {
250
+ setModalPos(-9999);
251
+ }
252
+ }, []);
253
+ return (0, _jsxRuntime.jsxs)(_reactPopover.Root, {
254
+ modal: _reactDeviceDetect.isMobile,
255
+ onOpenChange: onOpenChange,
256
+ children: [(0, _jsxRuntime.jsx)(StyledAnchor, {
257
+ ref: anchorRef
258
+ }), (0, _jsxRuntime.jsxs)(_Figure.Figure, {
259
+ resizeIframe: true,
260
+ type: fullWidth ? 'full' : 'full-column',
261
+ children: [(0, _jsxRuntime.jsx)(_Notion.Notion, {
262
+ id: "",
263
+ title: title,
264
+ text: content,
265
+ visualElement: (visualElement === null || visualElement === void 0 ? void 0 : visualElement.status) === 'success' && (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
266
+ children: [(0, _jsxRuntime.jsx)(ImageWrapper, {
267
+ children: (0, _jsxRuntime.jsx)(_tooltip["default"], {
268
+ tooltip: t('searchPage.resultType.showNotion'),
269
+ children: (0, _jsxRuntime.jsx)(_reactPopover.Trigger, {
270
+ asChild: true,
271
+ children: (0, _jsxRuntime.jsx)(StyledButton, {
272
+ type: "button",
273
+ "aria-label": t('concept.showDescription', {
274
+ title: title
275
+ }),
276
+ children: visualElement.resource === 'image' ? (0, _jsxRuntime.jsx)(_NotionImage.NotionImage, {
277
+ type: visualElementType,
278
+ id: '',
279
+ src: visualElement.data.imageUrl,
280
+ alt: visualElement.data.alttext.alttext
281
+ }) : metaImage ? (0, _jsxRuntime.jsx)(_NotionImage.NotionImage, {
282
+ type: visualElementType,
283
+ id: '',
284
+ src: (_metaImage$url = metaImage === null || metaImage === void 0 ? void 0 : metaImage.url) !== null && _metaImage$url !== void 0 ? _metaImage$url : '',
285
+ alt: (_metaImage$alt = metaImage === null || metaImage === void 0 ? void 0 : metaImage.alt) !== null && _metaImage$alt !== void 0 ? _metaImage$alt : ''
286
+ }) : undefined
287
+ })
288
+ })
289
+ })
290
+ }), (0, _jsxRuntime.jsx)(_reactPopover.Portal, {
291
+ container: typeof document !== 'undefined' ? document.querySelector('.c-article') || undefined : undefined,
292
+ children: (0, _jsxRuntime.jsx)(PopoverWrapper, {
293
+ top: modalPos,
294
+ children: (0, _jsxRuntime.jsx)(_reactPopover.Content, {
295
+ avoidCollisions: false,
296
+ asChild: true,
297
+ side: "bottom",
298
+ children: (0, _jsxRuntime.jsx)(_conceptComponents.ConceptNotionV2, {
299
+ title: title,
300
+ content: content,
301
+ copyright: copyright,
302
+ source: source,
303
+ visualElement: visualElement,
304
+ inPopover: true,
305
+ closeButton: (0, _jsxRuntime.jsx)(_reactPopover.Close, {
306
+ asChild: true,
307
+ children: (0, _jsxRuntime.jsx)(_button.IconButtonV2, {
308
+ "aria-label": t('close'),
309
+ variant: "ghost",
310
+ children: (0, _jsxRuntime.jsx)(_action.Cross, {})
311
+ })
312
+ })
313
+ })
314
+ })
315
+ })
316
+ })]
317
+ })
318
+ }), copyright !== null && copyright !== void 0 && copyright.license && license ? (0, _jsxRuntime.jsx)(_Figure.FigureCaption, {
319
+ figureId: "",
320
+ id: "",
321
+ authors: authors,
322
+ licenseRights: license.rights,
323
+ locale: i18n.language,
324
+ hideIconsAndAuthors: true,
325
+ modalButton: (0, _jsxRuntime.jsx)(_button.ButtonV2, {
326
+ variant: "outline",
327
+ size: "small",
328
+ shape: "pill",
329
+ onClick: function onClick() {
330
+ return setIsOpen(true);
331
+ },
332
+ children: t('concept.reuse')
333
+ }),
334
+ children: (0, _jsxRuntime.jsx)(_modal.ModalV2, {
335
+ controlled: true,
336
+ isOpen: isOpen,
337
+ onClose: function onClose() {
338
+ return setIsOpen(false);
339
+ },
340
+ labelledBy: "license-dialog-rules-heading",
341
+ children: function children(close) {
342
+ return (0, _jsxRuntime.jsx)(_FigureLicenseDialogContent.FigureLicenseDialogContent, {
343
+ authors: groupedAuthors,
344
+ locale: i18n.language,
345
+ title: title,
346
+ origin: copyright.origin,
347
+ license: license,
348
+ onClose: close,
349
+ type: "concept"
350
+ });
351
+ }
352
+ })
353
+ }) : (0, _jsxRuntime.jsx)(BottomBorder, {})]
354
+ })]
355
+ });
356
+ };
357
+ exports.BlockConcept = BlockConcept;
358
+ var _default = ConceptEmbed;
359
+ exports["default"] = _default;