@ndla/ui 34.6.1 → 34.6.3

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 +358 -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 +11 -1
  35. package/es/locale/messages-nb.js +11 -1
  36. package/es/locale/messages-nn.js +11 -1
  37. package/es/locale/messages-se.js +11 -1
  38. package/es/locale/messages-sma.js +11 -1
  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 +358 -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 +10 -0
  103. package/lib/locale/messages-en.js +11 -1
  104. package/lib/locale/messages-nb.d.ts +10 -0
  105. package/lib/locale/messages-nb.js +11 -1
  106. package/lib/locale/messages-nn.d.ts +10 -0
  107. package/lib/locale/messages-nn.js +11 -1
  108. package/lib/locale/messages-se.d.ts +10 -0
  109. package/lib/locale/messages-se.js +11 -1
  110. package/lib/locale/messages-sma.d.ts +10 -0
  111. package/lib/locale/messages-sma.js +11 -1
  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 +408 -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 +10 -0
  149. package/src/locale/messages-nb.ts +10 -0
  150. package/src/locale/messages-nn.ts +10 -0
  151. package/src/locale/messages-se.ts +10 -1
  152. package/src/locale/messages-sma.ts +10 -0
  153. package/src/types.ts +1 -1
@@ -0,0 +1,280 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ConceptNotionV2 = void 0;
7
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
+ var _react = require("react");
9
+ var _reactI18next = require("react-i18next");
10
+ var _reactAccordion = require("@radix-ui/react-accordion");
11
+ var _licenses = require("@ndla/licenses");
12
+ var _react2 = require("@emotion/react");
13
+ var _button = require("@ndla/button");
14
+ var _core = require("@ndla/core");
15
+ var _common = require("@ndla/icons/common");
16
+ var _util = require("@ndla/util");
17
+ var _notion = require("@ndla/notion");
18
+ var _Figure = require("../Figure");
19
+ var _FigureLicense = require("../Figure/FigureLicense");
20
+ var _ImageEmbed = require("./ImageEmbed");
21
+ var _jsxRuntime = require("@emotion/react/jsx-runtime");
22
+ var _excluded = ["visualElement", "articlePath", "title", "content", "source", "copyright", "closeButton", "inPopover", "previewAlt", "tags", "subjects"];
23
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
24
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
25
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
26
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
27
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
28
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
29
+ 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)."; }
30
+ var getConceptVisualElement = function getConceptVisualElement(visualElement) {
31
+ if (visualElement.status === 'error') {
32
+ return undefined;
33
+ }
34
+ if (visualElement.resource === 'image') {
35
+ return {
36
+ resource: visualElement.resource,
37
+ title: visualElement.data.title.title,
38
+ copyright: visualElement.data.copyright,
39
+ image: {
40
+ src: visualElement.data.imageUrl,
41
+ alt: visualElement.data.alttext.alttext
42
+ },
43
+ url: visualElement.data.imageUrl
44
+ };
45
+ } else if (visualElement.resource === 'brightcove') {
46
+ return {
47
+ resource: visualElement.resource,
48
+ title: visualElement.data.name,
49
+ url: "https://players.brightcove.net/".concat(visualElement.embedData.account, "/").concat(visualElement.embedData.player, "_default/index.html?videoId=").concat(visualElement.embedData.videoid),
50
+ copyright: visualElement.data.copyright
51
+ };
52
+ } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {
53
+ return {
54
+ resource: visualElement.resource,
55
+ url: visualElement.embedData.url,
56
+ title: visualElement.embedData.url
57
+ };
58
+ } else {
59
+ return {
60
+ resource: visualElement.resource,
61
+ url: visualElement.data.h5pUrl,
62
+ title: visualElement.embedData.title
63
+ };
64
+ }
65
+ };
66
+ var notionContentCss = /*#__PURE__*/(0, _react2.css)("@keyframes animateIn{0%{opacity:0;transform:translate3d(0, -13px, 0);}100%{opacity:1;transform:translate3d(0, 0, 0);}}animation-name:animateIn;animation-duration:300ms;padding:", _core.spacing.normal, ";background-color:white;z-index:1;box-shadow:0 0 30px rgba(0, 0, 0, 0.2);", _core.mq.range({
67
+ from: _core.breakpoints.tablet
68
+ }), "{width:500px;}", _core.mq.range({
69
+ from: _core.breakpoints.desktop
70
+ }), "{width:720px;}", _core.mq.range({
71
+ until: _core.breakpoints.tablet
72
+ }), "{padding:", _core.spacing.small, ";z-index:9999;height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmF4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
73
+ var StyledIframe = /*#__PURE__*/(0, _base["default"])("iframe", {
74
+ target: "eqcj3r9",
75
+ label: "StyledIframe"
76
+ })("height:auto;min-height:", function (p) {
77
+ return p.type === 'video' && '400px';
78
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqHqD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
79
+ var NotionHeader = /*#__PURE__*/(0, _base["default"])("div", {
80
+ target: "eqcj3r8",
81
+ label: "NotionHeader"
82
+ })("display:flex;align-items:center;justify-content:flex-end;border-bottom:2px solid ", _core.colors.brand.tertiary, ";padding-bottom:", _core.spacing.small, ";h1{flex-grow:1;margin:0;font-weight:", _core.fonts.weight.bold, ";", _core.fonts.sizes('22px', 1.2), ";}small{padding-left:", _core.spacing.small, ";margin-left:", _core.spacing.xsmall, ";border-left:1px solid ", _core.colors.brand.greyLight, ";", _core.fonts.sizes('20px', 1.2), ";font-weight:", _core.fonts.weight.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA0H+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
83
+ var StyledAccordionContent = /*#__PURE__*/(0, _base["default"])(_reactAccordion.Content, {
84
+ target: "eqcj3r7",
85
+ label: "StyledAccordionContent"
86
+ })("background-color:", _core.colors.brand.lighter, ";padding:", _core.spacing.small, ";border-radius:", _core.misc.borderRadius, ";overflow:hidden;&[data-state='open']{animation:slideDown 300ms ease-out;}&[data-state='closed']{animation:slideUp 300ms ease-out;}@keyframes slideDown{from{height:0;}to{height:var(--radix-accordion-content-height);}}@keyframes slideUp{from{height:var(--radix-accordion-content-height);}to{height:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+I8C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
87
+ var StyledRoot = /*#__PURE__*/(0, _base["default"])(_reactAccordion.Root, {
88
+ target: "eqcj3r6",
89
+ label: "StyledRoot"
90
+ })("border-bottom:1px solid ", _core.colors.brand.greyLight, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA4K+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
91
+ var StyledFigure = /*#__PURE__*/(0, _base["default"])(_Figure.Figure, {
92
+ target: "eqcj3r5",
93
+ label: "StyledFigure"
94
+ })("&&{margin:", _core.spacing.normal, " 0;}padding-bottom:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAgLmC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
95
+ var StyledFigureCaption = /*#__PURE__*/(0, _base["default"])(_Figure.FigureCaption, {
96
+ target: "eqcj3r4",
97
+ label: "StyledFigureCaption"
98
+ })(process.env.NODE_ENV === "production" ? {
99
+ name: "1s3qw3i",
100
+ styles: "border-bottom:0;h3{margin:0;}"
101
+ } : {
102
+ name: "1s3qw3i",
103
+ styles: "border-bottom:0;h3{margin:0;}",
104
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuLiD","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
105
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
106
+ });
107
+ var StyledSpan = /*#__PURE__*/(0, _base["default"])("span", {
108
+ target: "eqcj3r3",
109
+ label: "StyledSpan"
110
+ })(process.env.NODE_ENV === "production" ? {
111
+ name: "1t01il3",
112
+ styles: "font-style:italic;color:grey"
113
+ } : {
114
+ name: "1t01il3",
115
+ styles: "font-style:italic;color:grey",
116
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA+L8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */",
117
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
118
+ });
119
+ var StyledAccordionTrigger = /*#__PURE__*/(0, _base["default"])(_button.ButtonV2, {
120
+ target: "eqcj3r2",
121
+ label: "StyledAccordionTrigger"
122
+ })("color:", _core.colors.brand.primary, ";border-color:", _core.colors.brand.primary, ";&[data-state='open']{svg{transform:rotate(180deg);}}svg{transition:transform 300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoM+C","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
123
+ var ListWrapper = /*#__PURE__*/(0, _base["default"])("div", {
124
+ target: "eqcj3r1",
125
+ label: "ListWrapper"
126
+ })("display:flex;gap:", _core.spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAiN8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
127
+ var StyledList = /*#__PURE__*/(0, _base["default"])("ul", {
128
+ target: "eqcj3r0",
129
+ label: "StyledList"
130
+ })("display:flex;gap:", _core.spacing.small, ";align-items:center;list-style:none;>li{margin:0;font-family:", _core.fonts.sans, ";font-weight:", _core.fonts.weight.semibold, ";border-radius:", _core.misc.borderRadius, ";background-color:", _core.colors.brand.greyLightest, ";", _core.fonts.sizes('12px', 1.2), ";padding:", _core.spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAuN4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { forwardRef, ReactNode, RefAttributes, useEffect, useRef } from 'react';\nimport { ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { Root, Item, Header, Trigger, Content } from '@radix-ui/react-accordion';\nimport { getGroupedContributorDescriptionList, getLicenseByAbbreviation, getLicenseCredits } from '@ndla/licenses';\nimport { css } from '@emotion/react';\nimport { ButtonV2 } from '@ndla/button';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogLicenses, NotionDialogText } from '@ndla/notion';\nimport { Figure, FigureCaption } from '../Figure';\nimport { NotionVisualElementType } from '../Notion';\nimport { classLicenses, FigureLicenseByline, FigureLicenseCta } from '../Figure/FigureLicense';\nimport { Copyright } from '../types';\nimport { ImageLicenseButtons } from './ImageEmbed';\n\nexport interface ConceptNotionData {\n  title: string;\n  content?: string;\n  articlePath?: string;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n}\n\nconst getConceptVisualElement = (visualElement: ConceptVisualElementMeta): NotionVisualElementType | undefined => {\n  if (visualElement.status === 'error') {\n    return undefined;\n  }\n\n  if (visualElement.resource === 'image') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.title.title,\n      copyright: visualElement.data.copyright,\n      image: { src: visualElement.data.imageUrl, alt: visualElement.data.alttext.alttext },\n      url: visualElement.data.imageUrl,\n    };\n  } else if (visualElement.resource === 'brightcove') {\n    return {\n      resource: visualElement.resource,\n      title: visualElement.data.name,\n      url: `https://players.brightcove.net/${visualElement.embedData.account}/${visualElement.embedData.player}_default/index.html?videoId=${visualElement.embedData.videoid}`,\n      copyright: visualElement.data.copyright,\n    };\n  } else if (visualElement.resource === 'external' || visualElement.resource === 'iframe') {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.embedData.url,\n      title: visualElement.embedData.url,\n    };\n  } else {\n    return {\n      resource: visualElement.resource,\n      url: visualElement.data.h5pUrl,\n      title: visualElement.embedData.title,\n    };\n  }\n};\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  padding: ${spacing.normal};\n  background-color: white;\n  z-index: 1;\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: 9999;\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst StyledIframe = styled.iframe<{ type?: string }>`\n  height: auto;\n  min-height: ${(p) => p.type === 'video' && '400px'};\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes('22px', 1.2)};\n  }\n  small {\n    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n`;\n\nconst StyledAccordionContent = styled(Content)`\n  background-color: ${colors.brand.lighter};\n  padding: ${spacing.small};\n  border-radius: ${misc.borderRadius};\n  overflow: hidden;\n  &[data-state='open'] {\n    animation: slideDown 300ms ease-out;\n  }\n  &[data-state='closed'] {\n    animation: slideUp 300ms ease-out;\n  }\n  @keyframes slideDown {\n    from {\n      height: 0;\n    }\n    to {\n      height: var(--radix-accordion-content-height);\n    }\n  }\n  @keyframes slideUp {\n    from {\n      height: var(--radix-accordion-content-height);\n    }\n    to {\n      height: 0;\n    }\n  }\n`;\n\nconst StyledRoot = styled(Root)`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n`;\n\nconst StyledFigure = styled(Figure)`\n  && {\n    margin: ${spacing.normal} 0;\n  }\n  padding-bottom: 0;\n`;\n\nconst StyledFigureCaption = styled(FigureCaption)`\n  border-bottom: 0;\n\n  h3 {\n    margin: 0;\n  }\n`;\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst StyledAccordionTrigger = styled(ButtonV2)`\n  color: ${colors.brand.primary};\n  border-color: ${colors.brand.primary};\n  &[data-state='open'] {\n    svg {\n      transform: rotate(180deg);\n    }\n  }\n  svg {\n    transition: transform 300ms;\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes('12px', 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      articlePath,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t, i18n } = useTranslation();\n    const iframeRef = useRef<HTMLIFrameElement>(null);\n\n    useEffect(() => {\n      const iframe = iframeRef.current;\n      if (iframe) {\n        const [width, height] = [parseInt(iframe.width), parseInt(iframe.height)];\n        iframe.style.aspectRatio = `${width ? width : 16}/${height ? height : 9}`;\n      }\n    }, []);\n\n    const licenseCredits = getLicenseCredits(copyright);\n    const { creators, rightsholders, processors } = licenseCredits;\n    const authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;\n\n    const visualElementType =\n      visualElement?.embedData.resource === 'brightcove' ? 'video' : visualElement?.embedData.resource;\n\n    const notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;\n    const visualElementLicense = getLicenseByAbbreviation(\n      notionVisualElement?.copyright?.license?.license ?? '',\n      i18n.language,\n    );\n    const visualElementLicenseCredits = getLicenseCredits(notionVisualElement?.copyright);\n    const visualElementAuthors =\n      visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length\n        ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders)\n        : visualElementLicenseCredits.processors;\n    const visualElementGroupedAuthors = getGroupedContributorDescriptionList(\n      visualElementLicenseCredits,\n      i18n.language,\n    ).map((item) => ({\n      name: item.description,\n      type: item.label,\n    }));\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <NotionHeader>\n          <h1>\n            {title} {<small>{t('searchPage.resultType.notionsHeading')}</small>}\n          </h1>\n          {closeButton}\n        </NotionHeader>\n        <NotionDialogContent>\n          {notionVisualElement && (\n            <StyledFigure resizeIframe type={'full-column'}>\n              {notionVisualElement.image?.src ? (\n                <img src={notionVisualElement.image.src} alt={notionVisualElement.image.alt} />\n              ) : (\n                <StyledIframe\n                  ref={iframeRef}\n                  allowFullScreen\n                  type={visualElementType}\n                  src={notionVisualElement?.url}\n                  title={notionVisualElement?.title}\n                />\n              )}\n              {previewAlt && visualElement?.resource === 'image' ? (\n                <StyledSpan>{`Alt: ${visualElement.embedData.alt}`}</StyledSpan>\n              ) : null}\n              {visualElementLicense && (\n                <StyledRoot type=\"single\" collapsible>\n                  <Item value=\"licenseInfo\">\n                    <StyledFigureCaption\n                      figureId={''}\n                      id={''}\n                      modalButton={<></>}\n                      reuseLabel={t('reuse')}\n                      authors={visualElementAuthors}\n                      licenseRights={visualElementLicense.rights}>\n                      {visualElementLicense.abbreviation && (\n                        <Header>\n                          <Trigger asChild>\n                            <StyledAccordionTrigger variant=\"outline\" shape=\"pill\" size=\"small\" colorTheme=\"lighter\">\n                              {t('license.info')}\n                              <ChevronDown />\n                            </StyledAccordionTrigger>\n                          </Trigger>\n                        </Header>\n                      )}\n                    </StyledFigureCaption>\n                    <StyledAccordionContent>\n                      <div {...classLicenses()}>\n                        <h1 {...classLicenses('title')}>{t(`license.${visualElementType}.rules`)}</h1>\n                        <FigureLicenseByline\n                          license={visualElementLicense}\n                          messages={{\n                            learnAboutLicenses: t('license.learnMore'),\n                          }}\n                          locale={i18n.language}\n                        />\n                        <FigureLicenseCta\n                          authors={visualElementGroupedAuthors}\n                          title={notionVisualElement?.title}\n                          origin={notionVisualElement?.copyright?.origin}\n                          messages={{ source: t('source'), title: t('title') }}>\n                          {visualElementType === 'image' ? (\n                            <ImageLicenseButtons\n                              imageUrl={notionVisualElement.image?.src ?? ''}\n                              title={notionVisualElement.title}\n                              copyright={notionVisualElement.copyright}\n                              articlePath={articlePath}\n                            />\n                          ) : null}\n                        </FigureLicenseCta>\n                      </div>\n                    </StyledAccordionContent>\n                  </Item>\n                </StyledRoot>\n              )}\n            </StyledFigure>\n          )}\n          <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</NotionDialogText>\n        </NotionDialogContent>\n        {tags && (\n          <ListWrapper>\n            {`${t('notions.tags')}:`}\n            <StyledList>\n              {tags.map((tag, index) => (\n                <li key={index}>{tag}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n        {subjects && (\n          <ListWrapper>\n            {`${t('notions.usedIn')}:`}\n            <StyledList>\n              {subjects.map((subject, index) => (\n                <li key={index}>{subject}</li>\n              ))}\n            </StyledList>\n          </ListWrapper>\n        )}\n\n        <NotionDialogLicenses\n          authors={authors.map((a) => a.name)}\n          license={copyright?.license?.license ?? ''}\n          source={parseMarkdown(source ?? '', 'body')}\n        />\n      </div>\n    );\n  },\n);\n"]} */"));
131
+ var ConceptNotionV2 = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
132
+ var _notionVisualElement$, _notionVisualElement$2, _notionVisualElement$3, _notionVisualElement$4, _notionVisualElement$5, _notionVisualElement$6, _notionVisualElement$7, _copyright$license$li, _copyright$license;
133
+ var visualElement = _ref.visualElement,
134
+ articlePath = _ref.articlePath,
135
+ title = _ref.title,
136
+ content = _ref.content,
137
+ source = _ref.source,
138
+ copyright = _ref.copyright,
139
+ closeButton = _ref.closeButton,
140
+ inPopover = _ref.inPopover,
141
+ previewAlt = _ref.previewAlt,
142
+ tags = _ref.tags,
143
+ subjects = _ref.subjects,
144
+ rest = _objectWithoutProperties(_ref, _excluded);
145
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
146
+ t = _useTranslation.t,
147
+ i18n = _useTranslation.i18n;
148
+ var iframeRef = (0, _react.useRef)(null);
149
+ (0, _react.useEffect)(function () {
150
+ var iframe = iframeRef.current;
151
+ if (iframe) {
152
+ var _ref2 = [parseInt(iframe.width), parseInt(iframe.height)],
153
+ width = _ref2[0],
154
+ height = _ref2[1];
155
+ iframe.style.aspectRatio = "".concat(width ? width : 16, "/").concat(height ? height : 9);
156
+ }
157
+ }, []);
158
+ var licenseCredits = (0, _licenses.getLicenseCredits)(copyright);
159
+ var creators = licenseCredits.creators,
160
+ rightsholders = licenseCredits.rightsholders,
161
+ processors = licenseCredits.processors;
162
+ var authors = creators.length || rightsholders.length ? creators.concat(rightsholders) : processors;
163
+ var visualElementType = (visualElement === null || visualElement === void 0 ? void 0 : visualElement.embedData.resource) === 'brightcove' ? 'video' : visualElement === null || visualElement === void 0 ? void 0 : visualElement.embedData.resource;
164
+ var notionVisualElement = visualElement ? getConceptVisualElement(visualElement) : undefined;
165
+ var visualElementLicense = (0, _licenses.getLicenseByAbbreviation)((_notionVisualElement$ = notionVisualElement === null || notionVisualElement === void 0 ? void 0 : (_notionVisualElement$2 = notionVisualElement.copyright) === null || _notionVisualElement$2 === void 0 ? void 0 : (_notionVisualElement$3 = _notionVisualElement$2.license) === null || _notionVisualElement$3 === void 0 ? void 0 : _notionVisualElement$3.license) !== null && _notionVisualElement$ !== void 0 ? _notionVisualElement$ : '', i18n.language);
166
+ var visualElementLicenseCredits = (0, _licenses.getLicenseCredits)(notionVisualElement === null || notionVisualElement === void 0 ? void 0 : notionVisualElement.copyright);
167
+ var visualElementAuthors = visualElementLicenseCredits.creators.length || visualElementLicenseCredits.rightsholders.length ? visualElementLicenseCredits.creators.concat(visualElementLicenseCredits.rightsholders) : visualElementLicenseCredits.processors;
168
+ var visualElementGroupedAuthors = (0, _licenses.getGroupedContributorDescriptionList)(visualElementLicenseCredits, i18n.language).map(function (item) {
169
+ return {
170
+ name: item.description,
171
+ type: item.label
172
+ };
173
+ });
174
+ return (0, _jsxRuntime.jsxs)("div", _objectSpread(_objectSpread({
175
+ css: inPopover ? notionContentCss : undefined
176
+ }, rest), {}, {
177
+ ref: ref,
178
+ children: [(0, _jsxRuntime.jsxs)(NotionHeader, {
179
+ children: [(0, _jsxRuntime.jsxs)("h1", {
180
+ children: [title, " ", (0, _jsxRuntime.jsx)("small", {
181
+ children: t('searchPage.resultType.notionsHeading')
182
+ })]
183
+ }), closeButton]
184
+ }), (0, _jsxRuntime.jsxs)(_notion.NotionDialogContent, {
185
+ children: [notionVisualElement && (0, _jsxRuntime.jsxs)(StyledFigure, {
186
+ resizeIframe: true,
187
+ type: 'full-column',
188
+ children: [(_notionVisualElement$4 = notionVisualElement.image) !== null && _notionVisualElement$4 !== void 0 && _notionVisualElement$4.src ? (0, _jsxRuntime.jsx)("img", {
189
+ src: notionVisualElement.image.src,
190
+ alt: notionVisualElement.image.alt
191
+ }) : (0, _jsxRuntime.jsx)(StyledIframe, {
192
+ ref: iframeRef,
193
+ allowFullScreen: true,
194
+ type: visualElementType,
195
+ src: notionVisualElement === null || notionVisualElement === void 0 ? void 0 : notionVisualElement.url,
196
+ title: notionVisualElement === null || notionVisualElement === void 0 ? void 0 : notionVisualElement.title
197
+ }), previewAlt && (visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'image' ? (0, _jsxRuntime.jsx)(StyledSpan, {
198
+ children: "Alt: ".concat(visualElement.embedData.alt)
199
+ }) : null, visualElementLicense && (0, _jsxRuntime.jsx)(StyledRoot, {
200
+ type: "single",
201
+ collapsible: true,
202
+ children: (0, _jsxRuntime.jsxs)(_reactAccordion.Item, {
203
+ value: "licenseInfo",
204
+ children: [(0, _jsxRuntime.jsx)(StyledFigureCaption, {
205
+ figureId: '',
206
+ id: '',
207
+ modalButton: (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {}),
208
+ reuseLabel: t('reuse'),
209
+ authors: visualElementAuthors,
210
+ licenseRights: visualElementLicense.rights,
211
+ children: visualElementLicense.abbreviation && (0, _jsxRuntime.jsx)(_reactAccordion.Header, {
212
+ children: (0, _jsxRuntime.jsx)(_reactAccordion.Trigger, {
213
+ asChild: true,
214
+ children: (0, _jsxRuntime.jsxs)(StyledAccordionTrigger, {
215
+ variant: "outline",
216
+ shape: "pill",
217
+ size: "small",
218
+ colorTheme: "lighter",
219
+ children: [t('license.info'), (0, _jsxRuntime.jsx)(_common.ChevronDown, {})]
220
+ })
221
+ })
222
+ })
223
+ }), (0, _jsxRuntime.jsx)(StyledAccordionContent, {
224
+ children: (0, _jsxRuntime.jsxs)("div", _objectSpread(_objectSpread({}, (0, _FigureLicense.classLicenses)()), {}, {
225
+ children: [(0, _jsxRuntime.jsx)("h1", _objectSpread(_objectSpread({}, (0, _FigureLicense.classLicenses)('title')), {}, {
226
+ children: t("license.".concat(visualElementType, ".rules"))
227
+ })), (0, _jsxRuntime.jsx)(_FigureLicense.FigureLicenseByline, {
228
+ license: visualElementLicense,
229
+ messages: {
230
+ learnAboutLicenses: t('license.learnMore')
231
+ },
232
+ locale: i18n.language
233
+ }), (0, _jsxRuntime.jsx)(_FigureLicense.FigureLicenseCta, {
234
+ authors: visualElementGroupedAuthors,
235
+ title: notionVisualElement === null || notionVisualElement === void 0 ? void 0 : notionVisualElement.title,
236
+ origin: notionVisualElement === null || notionVisualElement === void 0 ? void 0 : (_notionVisualElement$5 = notionVisualElement.copyright) === null || _notionVisualElement$5 === void 0 ? void 0 : _notionVisualElement$5.origin,
237
+ messages: {
238
+ source: t('source'),
239
+ title: t('title')
240
+ },
241
+ children: visualElementType === 'image' ? (0, _jsxRuntime.jsx)(_ImageEmbed.ImageLicenseButtons, {
242
+ imageUrl: (_notionVisualElement$6 = (_notionVisualElement$7 = notionVisualElement.image) === null || _notionVisualElement$7 === void 0 ? void 0 : _notionVisualElement$7.src) !== null && _notionVisualElement$6 !== void 0 ? _notionVisualElement$6 : '',
243
+ title: notionVisualElement.title,
244
+ copyright: notionVisualElement.copyright,
245
+ articlePath: articlePath
246
+ }) : null
247
+ })]
248
+ }))
249
+ })]
250
+ })
251
+ })]
252
+ }), (0, _jsxRuntime.jsx)(_notion.NotionDialogText, {
253
+ children: (0, _util.parseMarkdown)(content !== null && content !== void 0 ? content : '', 'body')
254
+ })]
255
+ }), tags && (0, _jsxRuntime.jsxs)(ListWrapper, {
256
+ children: ["".concat(t('notions.tags'), ":"), (0, _jsxRuntime.jsx)(StyledList, {
257
+ children: tags.map(function (tag, index) {
258
+ return (0, _jsxRuntime.jsx)("li", {
259
+ children: tag
260
+ }, index);
261
+ })
262
+ })]
263
+ }), subjects && (0, _jsxRuntime.jsxs)(ListWrapper, {
264
+ children: ["".concat(t('notions.usedIn'), ":"), (0, _jsxRuntime.jsx)(StyledList, {
265
+ children: subjects.map(function (subject, index) {
266
+ return (0, _jsxRuntime.jsx)("li", {
267
+ children: subject
268
+ }, index);
269
+ })
270
+ })]
271
+ }), (0, _jsxRuntime.jsx)(_notion.NotionDialogLicenses, {
272
+ authors: authors.map(function (a) {
273
+ return a.name;
274
+ }),
275
+ license: (_copyright$license$li = copyright === null || copyright === void 0 ? void 0 : (_copyright$license = copyright.license) === null || _copyright$license === void 0 ? void 0 : _copyright$license.license) !== null && _copyright$license$li !== void 0 ? _copyright$license$li : '',
276
+ source: (0, _util.parseMarkdown)(source !== null && source !== void 0 ? source : '', 'body')
277
+ })]
278
+ }));
279
+ });
280
+ exports.ConceptNotionV2 = ConceptNotionV2;