@ndla/ui 34.6.1 → 34.6.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Article/Article.js +11 -6
- package/es/Aside/Aside.js +5 -2
- package/es/CopyParagraphButton/CopyParagraphButtonV2.js +85 -0
- package/es/CopyParagraphButton/index.js +2 -1
- package/es/Embed/AudioEmbed.js +254 -0
- package/es/Embed/BrightcoveEmbed.js +250 -0
- package/es/Embed/ConceptEmbed.js +358 -0
- package/es/Embed/ConceptListEmbed.js +71 -0
- package/es/Embed/ContentLinkEmbed.js +42 -0
- package/es/Embed/ExternalEmbed.js +91 -0
- package/es/Embed/FootnoteEmbed.js +32 -0
- package/es/Embed/H5pEmbed.js +87 -0
- package/es/Embed/IframeEmbed.js +83 -0
- package/es/Embed/ImageEmbed.js +322 -0
- package/es/Embed/RelatedContentEmbed.js +58 -0
- package/es/Embed/UnknownEmbed.js +27 -0
- package/es/Embed/conceptComponents.js +282 -0
- package/es/Embed/index.js +21 -0
- package/es/FactBox/FactBoxV2.js +90 -0
- package/es/FactBox/index.js +1 -0
- package/es/Figure/Figure.js +8 -5
- package/es/Figure/FigureLicenseDialogContent.js +72 -0
- package/es/FileList/FileListV2.js +47 -0
- package/es/FileList/FileV2.js +34 -0
- package/es/FileList/PdfFile.js +25 -0
- package/es/FileList/index.js +3 -0
- package/es/Notion/Notion.js +5 -5
- package/es/Notion/NotionVisualElement.js +2 -2
- package/es/RelatedArticleList/RelatedArticleV2.js +101 -0
- package/es/RelatedArticleList/index.js +2 -1
- package/es/Table/Table.js +95 -8
- package/es/all.css +1 -1
- package/es/index.js +5 -4
- package/es/locale/messages-en.js +11 -1
- package/es/locale/messages-nb.js +11 -1
- package/es/locale/messages-nn.js +11 -1
- package/es/locale/messages-se.js +11 -1
- package/es/locale/messages-sma.js +11 -1
- package/lib/Article/Article.d.ts +2 -1
- package/lib/Article/Article.js +11 -6
- package/lib/Aside/Aside.d.ts +2 -1
- package/lib/Aside/Aside.js +5 -2
- package/lib/CopyParagraphButton/CopyParagraphButtonV2.d.ts +14 -0
- package/lib/CopyParagraphButton/CopyParagraphButtonV2.js +84 -0
- package/lib/CopyParagraphButton/index.d.ts +2 -1
- package/lib/CopyParagraphButton/index.js +7 -0
- package/lib/Embed/AudioEmbed.d.ts +20 -0
- package/lib/Embed/AudioEmbed.js +252 -0
- package/lib/Embed/BrightcoveEmbed.d.ts +16 -0
- package/lib/Embed/BrightcoveEmbed.js +250 -0
- package/lib/Embed/ConceptEmbed.d.ts +19 -0
- package/lib/Embed/ConceptEmbed.js +358 -0
- package/lib/Embed/ConceptListEmbed.d.ts +13 -0
- package/lib/Embed/ConceptListEmbed.js +70 -0
- package/lib/Embed/ContentLinkEmbed.d.ts +14 -0
- package/lib/Embed/ContentLinkEmbed.js +50 -0
- package/lib/Embed/ExternalEmbed.d.ts +14 -0
- package/lib/Embed/ExternalEmbed.js +90 -0
- package/lib/Embed/FootnoteEmbed.d.ts +13 -0
- package/lib/Embed/FootnoteEmbed.js +39 -0
- package/lib/Embed/H5pEmbed.d.ts +14 -0
- package/lib/Embed/H5pEmbed.js +86 -0
- package/lib/Embed/IframeEmbed.d.ts +14 -0
- package/lib/Embed/IframeEmbed.js +91 -0
- package/lib/Embed/ImageEmbed.d.ts +37 -0
- package/lib/Embed/ImageEmbed.js +326 -0
- package/lib/Embed/RelatedContentEmbed.d.ts +16 -0
- package/lib/Embed/RelatedContentEmbed.js +64 -0
- package/lib/Embed/UnknownEmbed.d.ts +13 -0
- package/lib/Embed/UnknownEmbed.js +35 -0
- package/lib/Embed/conceptComponents.d.ts +32 -0
- package/lib/Embed/conceptComponents.js +280 -0
- package/lib/Embed/index.d.ts +20 -0
- package/lib/Embed/index.js +97 -0
- package/lib/FactBox/FactBoxV2.d.ts +13 -0
- package/lib/FactBox/FactBoxV2.js +92 -0
- package/lib/FactBox/index.d.ts +1 -0
- package/lib/FactBox/index.js +7 -0
- package/lib/Figure/Figure.d.ts +5 -2
- package/lib/Figure/Figure.js +8 -5
- package/lib/Figure/FigureLicenseDialogContent.d.ts +22 -0
- package/lib/Figure/FigureLicenseDialogContent.js +71 -0
- package/lib/FileList/FileListV2.d.ts +13 -0
- package/lib/FileList/FileListV2.js +46 -0
- package/lib/FileList/FileV2.d.ts +16 -0
- package/lib/FileList/FileV2.js +42 -0
- package/lib/FileList/PdfFile.d.ts +13 -0
- package/lib/FileList/PdfFile.js +31 -0
- package/lib/FileList/index.d.ts +3 -0
- package/lib/FileList/index.js +21 -0
- package/lib/Notion/Notion.js +5 -5
- package/lib/Notion/NotionVisualElement.d.ts +1 -1
- package/lib/Notion/NotionVisualElement.js +2 -2
- package/lib/RelatedArticleList/RelatedArticleV2.d.ts +25 -0
- package/lib/RelatedArticleList/RelatedArticleV2.js +101 -0
- package/lib/RelatedArticleList/index.d.ts +2 -1
- package/lib/RelatedArticleList/index.js +7 -0
- package/lib/Table/Table.js +98 -8
- package/lib/all.css +1 -1
- package/lib/index.d.ts +5 -4
- package/lib/index.js +117 -2
- package/lib/locale/messages-en.d.ts +10 -0
- package/lib/locale/messages-en.js +11 -1
- package/lib/locale/messages-nb.d.ts +10 -0
- package/lib/locale/messages-nb.js +11 -1
- package/lib/locale/messages-nn.d.ts +10 -0
- package/lib/locale/messages-nn.js +11 -1
- package/lib/locale/messages-se.d.ts +10 -0
- package/lib/locale/messages-se.js +11 -1
- package/lib/locale/messages-sma.d.ts +10 -0
- package/lib/locale/messages-sma.js +11 -1
- package/lib/types.d.ts +1 -1
- package/package.json +16 -12
- package/src/Article/Article.tsx +8 -3
- package/src/Aside/Aside.tsx +9 -1
- package/src/Aside/component.aside.scss +3 -0
- package/src/CopyParagraphButton/CopyParagraphButtonV2.tsx +84 -0
- package/src/CopyParagraphButton/index.tsx +2 -1
- package/src/Embed/AudioEmbed.tsx +249 -0
- package/src/Embed/BrightcoveEmbed.tsx +203 -0
- package/src/Embed/ConceptEmbed.tsx +408 -0
- package/src/Embed/ConceptListEmbed.tsx +64 -0
- package/src/Embed/ContentLinkEmbed.tsx +41 -0
- package/src/Embed/ExternalEmbed.tsx +80 -0
- package/src/Embed/FootnoteEmbed.tsx +30 -0
- package/src/Embed/H5pEmbed.tsx +74 -0
- package/src/Embed/IframeEmbed.tsx +84 -0
- package/src/Embed/ImageEmbed.tsx +314 -0
- package/src/Embed/RelatedContentEmbed.tsx +62 -0
- package/src/Embed/UnknownEmbed.tsx +27 -0
- package/src/Embed/conceptComponents.tsx +393 -0
- package/src/Embed/index.ts +21 -0
- package/src/FactBox/FactBoxV2.tsx +56 -0
- package/src/FactBox/index.ts +2 -0
- package/src/Figure/Figure.tsx +28 -15
- package/src/Figure/FigureLicenseDialogContent.tsx +80 -0
- package/src/Figure/component.figure.scss +0 -1
- package/src/FileList/FileListV2.tsx +58 -0
- package/src/FileList/FileV2.tsx +35 -0
- package/src/FileList/PdfFile.tsx +25 -0
- package/src/FileList/index.ts +3 -0
- package/src/Notion/Notion.tsx +0 -1
- package/src/Notion/NotionVisualElement.tsx +1 -1
- package/src/RelatedArticleList/RelatedArticleV2.tsx +84 -0
- package/src/RelatedArticleList/index.ts +2 -1
- package/src/Table/Table.tsx +77 -4
- package/src/index.ts +19 -4
- package/src/locale/messages-en.ts +10 -0
- package/src/locale/messages-nb.ts +10 -0
- package/src/locale/messages-nn.ts +10 -0
- package/src/locale/messages-se.ts +10 -1
- package/src/locale/messages-sma.ts +10 -0
- 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
|
+
});
|