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