@ndla/ui 34.6.2 → 34.6.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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 +8 -1
- package/es/locale/messages-nb.js +8 -1
- package/es/locale/messages-nn.js +8 -1
- package/es/locale/messages-se.js +8 -1
- package/es/locale/messages-sma.js +8 -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 +7 -0
- package/lib/locale/messages-en.js +8 -1
- package/lib/locale/messages-nb.d.ts +7 -0
- package/lib/locale/messages-nb.js +8 -1
- package/lib/locale/messages-nn.d.ts +7 -0
- package/lib/locale/messages-nn.js +8 -1
- package/lib/locale/messages-se.d.ts +7 -0
- package/lib/locale/messages-se.js +8 -1
- package/lib/locale/messages-sma.d.ts +7 -0
- package/lib/locale/messages-sma.js +8 -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 +7 -0
- package/src/locale/messages-nb.ts +7 -0
- package/src/locale/messages-nn.ts +7 -0
- package/src/locale/messages-se.ts +7 -0
- package/src/locale/messages-sma.ts +7 -0
- package/src/types.ts +1 -1
|
@@ -0,0 +1,326 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.getLicenseCredits = exports.errorSvgSrc = exports["default"] = exports.ImageLicenseButtons = void 0;
|
|
8
|
+
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
9
|
+
var _isNumber = _interopRequireDefault(require("lodash/isNumber"));
|
|
10
|
+
var _licenses = require("@ndla/licenses");
|
|
11
|
+
var _reactI18next = require("react-i18next");
|
|
12
|
+
var _modal = require("@ndla/modal");
|
|
13
|
+
var _safelink = require("@ndla/safelink");
|
|
14
|
+
var _react = require("react");
|
|
15
|
+
var _button = require("@ndla/button");
|
|
16
|
+
var _action = require("@ndla/icons/action");
|
|
17
|
+
var _common = require("@ndla/icons/common");
|
|
18
|
+
var _Figure = require("../Figure");
|
|
19
|
+
var _Image = _interopRequireWildcard(require("../Image"));
|
|
20
|
+
var _FigureLicenseDialogContent = require("../Figure/FigureLicenseDialogContent");
|
|
21
|
+
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
22
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
23
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
24
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
25
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
26
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
27
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
28
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
29
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
30
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
31
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
32
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
33
|
+
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
34
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
35
|
+
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)."; }
|
|
36
|
+
var getLicenseCredits = function getLicenseCredits(copyright) {
|
|
37
|
+
var _copyright$creators, _copyright$rightshold, _copyright$processors;
|
|
38
|
+
return {
|
|
39
|
+
creators: (_copyright$creators = copyright === null || copyright === void 0 ? void 0 : copyright.creators) !== null && _copyright$creators !== void 0 ? _copyright$creators : [],
|
|
40
|
+
rightsholders: (_copyright$rightshold = copyright === null || copyright === void 0 ? void 0 : copyright.rightsholders) !== null && _copyright$rightshold !== void 0 ? _copyright$rightshold : [],
|
|
41
|
+
processors: (_copyright$processors = copyright === null || copyright === void 0 ? void 0 : copyright.processors) !== null && _copyright$processors !== void 0 ? _copyright$processors : []
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
exports.getLicenseCredits = getLicenseCredits;
|
|
45
|
+
var errorSvgSrc = "data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E";
|
|
46
|
+
exports.errorSvgSrc = errorSvgSrc;
|
|
47
|
+
var isSmall = function isSmall(size) {
|
|
48
|
+
return size === 'xsmall' || size === 'small';
|
|
49
|
+
};
|
|
50
|
+
var isAlign = function isAlign(align) {
|
|
51
|
+
return align === 'left' || align === 'right';
|
|
52
|
+
};
|
|
53
|
+
var getFigureType = function getFigureType(size, align) {
|
|
54
|
+
if (size && isSmall(size) && align && isAlign(align)) {
|
|
55
|
+
return "".concat(size, "-").concat(align);
|
|
56
|
+
}
|
|
57
|
+
if (size && isSmall(size) && !align) {
|
|
58
|
+
return size;
|
|
59
|
+
}
|
|
60
|
+
if (align && isAlign(align)) {
|
|
61
|
+
return align;
|
|
62
|
+
}
|
|
63
|
+
return 'full';
|
|
64
|
+
};
|
|
65
|
+
var getSizes = function getSizes(size, align) {
|
|
66
|
+
if (align && size === 'full') {
|
|
67
|
+
return '(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw';
|
|
68
|
+
}
|
|
69
|
+
if (align && size === 'small') {
|
|
70
|
+
return '(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw';
|
|
71
|
+
}
|
|
72
|
+
if (align && size === 'xsmall') {
|
|
73
|
+
return '(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw';
|
|
74
|
+
}
|
|
75
|
+
return '(min-width: 1024px) 1024px, 100vw';
|
|
76
|
+
};
|
|
77
|
+
var getFocalPoint = function getFocalPoint(data) {
|
|
78
|
+
if ((0, _isNumber["default"])(data.focalX) && (0, _isNumber["default"])(data.focalY)) {
|
|
79
|
+
return {
|
|
80
|
+
x: data.focalX,
|
|
81
|
+
y: data.focalY
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
return undefined;
|
|
85
|
+
};
|
|
86
|
+
var getCrop = function getCrop(data) {
|
|
87
|
+
if ((0, _isNumber["default"])(data.lowerRightX) && (0, _isNumber["default"])(data.lowerRightY) && (0, _isNumber["default"])(data.upperLeftX) && (0, _isNumber["default"])(data.upperLeftY)) {
|
|
88
|
+
return {
|
|
89
|
+
startX: data.lowerRightX,
|
|
90
|
+
startY: data.lowerRightY,
|
|
91
|
+
endX: data.upperLeftX,
|
|
92
|
+
endY: data.upperLeftY
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
return undefined;
|
|
96
|
+
};
|
|
97
|
+
var StyledSpan = /*#__PURE__*/(0, _base["default"])("span", {
|
|
98
|
+
target: "ened8ka0",
|
|
99
|
+
label: "StyledSpan"
|
|
100
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
101
|
+
name: "1t01il3",
|
|
102
|
+
styles: "font-style:italic;color:grey"
|
|
103
|
+
} : {
|
|
104
|
+
name: "1t01il3",
|
|
105
|
+
styles: "font-style:italic;color:grey",
|
|
106
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAsG8B","file":"ImageEmbed.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 isNumber from 'lodash/isNumber';\nimport styled from '@emotion/styled';\nimport { figureApa7CopyString, getGroupedContributorDescriptionList, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { ImageEmbedData, ImageMetaData } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { ModalV2 } from '@ndla/modal';\nimport { SafeLinkButton } from '@ndla/safelink';\nimport { MouseEventHandler, useState } from 'react';\nimport { ButtonV2, CopyButton } from '@ndla/button';\nimport { ExpandTwoArrows } from '@ndla/icons/action';\nimport { ArrowCollapse, ChevronDown, ChevronUp } from '@ndla/icons/common';\nimport { Figure, FigureCaption, FigureType } from '../Figure';\nimport Image, { ImageLink } from '../Image';\nimport { FigureLicenseDialogContent } from '../Figure/FigureLicenseDialogContent';\nimport { Copyright } from '../types';\n\ninterface Props {\n  embed: ImageMetaData;\n  articlePath?: string;\n  previewAlt?: boolean;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is 'xsmall' | 'small' => size === 'xsmall' || size === 'small';\n\nconst isAlign = (align?: string): align is 'left' | 'right' => align === 'left' || align === 'right';\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return 'full';\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === 'full') {\n    return '(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw';\n  }\n  if (align && size === 'small') {\n    return '(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw';\n  }\n  if (align && size === 'xsmall') {\n    return '(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw';\n  }\n  return '(min-width: 1024px) 1024px, 100vw';\n};\n\nconst getFocalPoint = (data: ImageEmbedData) => {\n  if (isNumber(data.focalX) && isNumber(data.focalY)) {\n    return { x: data.focalX, y: data.focalY };\n  }\n  return undefined;\n};\n\nconst getCrop = (data: ImageEmbedData) => {\n  if (\n    isNumber(data.lowerRightX) &&\n    isNumber(data.lowerRightY) &&\n    isNumber(data.upperLeftX) &&\n    isNumber(data.upperLeftY)\n  ) {\n    return {\n      startX: data.lowerRightX,\n      startY: data.lowerRightY,\n      endX: data.upperLeftX,\n      endY: data.upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst StyledSpan = styled.span`\n  font-style: italic;\n  color: grey;\n`;\n\nconst expandedSizes = '(min-width: 1024px) 1024px, 100vw';\n\nconst ImageEmbed = ({ embed, articlePath, previewAlt }: Props) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData.size));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n  const { t, i18n } = useTranslation();\n  if (embed.status === 'error') {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return (\n      <Figure type={figureType}>\n        <div className=\"c-figure__img\">\n          <img alt={t('image.error.url')} src={errorSvgSrc} />\n        </div>\n        <figcaption>{t('image.error.caption')}</figcaption>\n      </Figure>\n    );\n  }\n\n  const { data, embedData, seq } = embed;\n\n  const authors = getLicenseCredits(data.copyright);\n\n  const altText = embedData.alt || '';\n  const caption = embedData.caption || '';\n  const license = getLicenseByAbbreviation(data.copyright.license.license, i18n.language);\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const contributors = getGroupedContributorDescriptionList(data.copyright, i18n.language).map((item) => ({\n    name: item.description,\n    type: item.label,\n  }));\n\n  const figureId = `figure-${seq}-${data.id}`;\n\n  const { creators, rightsholders, processors } = authors;\n  const captionAuthors = creators.length || rightsholders.length ? [...creators, ...rightsholders] : processors;\n  return (\n    <Figure\n      id={figureId}\n      type={imageSizes ? undefined : figureType}\n      className={imageSizes ? 'c-figure--right expanded' : ''}>\n      <ImageWrapper src={data.imageUrl} crop={crop} size={embedData.size}>\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.imageUrl}\n          expandButton={\n            <ExpandButton\n              size={embedData.size}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => setImageSizes((p) => (p ? undefined : expandedSizes))}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n        />\n      </ImageWrapper>\n      {previewAlt ? <StyledSpan>{`Alt: ${embedData.alt}`}</StyledSpan> : null}\n      <FigureCaption\n        hideFigcaption={isSmall(embedData.size) || isBylineHidden}\n        figureId={figureId}\n        id={figureId}\n        caption={caption}\n        reuseLabel={t('image.reuse')}\n        modalButton={\n          <ButtonV2 shape=\"pill\" variant=\"outline\" size=\"small\" onClick={() => setIsOpen(true)}>\n            {t('image.reuse')}\n          </ButtonV2>\n        }\n        licenseRights={license.rights}\n        authors={captionAuthors}\n        locale={i18n.language}>\n        <ModalV2 controlled isOpen={isOpen} onClose={() => setIsOpen(false)} labelledBy=\"license-dialog-rules-heading\">\n          {(close) => (\n            <FigureLicenseDialogContent\n              title={data.title.title}\n              license={license}\n              onClose={close}\n              authors={contributors}\n              origin={data.copyright.origin}\n              locale={i18n.language}\n              type=\"image\">\n              <ImageLicenseButtons\n                articlePath={articlePath}\n                title={data.title.title}\n                imageUrl={data.imageUrl}\n                copyright={data.copyright}\n              />\n            </FigureLicenseDialogContent>\n          )}\n        </ModalV2>\n      </FigureCaption>\n    </Figure>\n  );\n};\n\ninterface ImageWrapperProps {\n  src: string;\n  children: React.ReactNode;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  size?: string;\n}\nconst hideByline = (size?: string): boolean => {\n  return !!size && size.endsWith('-hide-byline');\n};\n\ninterface ImageLicenseButtonsProps {\n  imageUrl: string;\n  title?: string;\n  articlePath?: string;\n  copyright?: Partial<Copyright>;\n}\n\nexport const ImageLicenseButtons = ({ imageUrl, title, articlePath, copyright }: ImageLicenseButtonsProps) => {\n  const { t, i18n } = useTranslation();\n  if (!copyright?.license?.license || copyright?.license?.license === 'COPYRIGHTED') return null;\n\n  const copyString = figureApa7CopyString(\n    title,\n    undefined,\n    imageUrl,\n    articlePath,\n    copyright,\n    copyright?.license?.license,\n    '',\n    t,\n    i18n.language,\n  );\n\n  return (\n    <>\n      <CopyButton\n        variant=\"outline\"\n        onClick={() => navigator.clipboard.writeText(copyString)}\n        copyNode={t('license.hasCopiedTitle')}\n        aria-live=\"assertive\">\n        {t('license.copyTitle')}\n      </CopyButton>\n      <SafeLinkButton to={`${imageUrl}?download=true`} download variant=\"outline\">\n        {t('image.download')}\n      </SafeLinkButton>\n    </>\n  );\n};\n\nconst ImageWrapper = ({ src, crop, size, children }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size) || hideByline(size)) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop} aria-label={t('license.images.itemImage.ariaLabel')}>\n      {children}\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  size?: string;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst ExpandButton = ({ size, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__fullscreen-btn\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? 'Out' : ''}ImageButtonLabel`)}\n        onClick={onExpand}>\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  } else if (hideByline(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__show-byline-btn\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? 'expandByline' : 'minimizeByline'}`)}\n        onClick={onHideByline}>\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </button>\n    );\n  } else return null;\n};\n\nexport default ImageEmbed;\n"]} */",
|
|
107
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
108
|
+
});
|
|
109
|
+
var expandedSizes = '(min-width: 1024px) 1024px, 100vw';
|
|
110
|
+
var ImageEmbed = function ImageEmbed(_ref) {
|
|
111
|
+
var embed = _ref.embed,
|
|
112
|
+
articlePath = _ref.articlePath,
|
|
113
|
+
previewAlt = _ref.previewAlt;
|
|
114
|
+
var _useState = (0, _react.useState)(false),
|
|
115
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
116
|
+
isOpen = _useState2[0],
|
|
117
|
+
setIsOpen = _useState2[1];
|
|
118
|
+
var _useState3 = (0, _react.useState)(hideByline(embed.embedData.size)),
|
|
119
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
120
|
+
isBylineHidden = _useState4[0],
|
|
121
|
+
setIsBylineHidden = _useState4[1];
|
|
122
|
+
var _useState5 = (0, _react.useState)(undefined),
|
|
123
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
124
|
+
imageSizes = _useState6[0],
|
|
125
|
+
setImageSizes = _useState6[1];
|
|
126
|
+
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
127
|
+
t = _useTranslation.t,
|
|
128
|
+
i18n = _useTranslation.i18n;
|
|
129
|
+
if (embed.status === 'error') {
|
|
130
|
+
var _embed$embedData = embed.embedData,
|
|
131
|
+
align = _embed$embedData.align,
|
|
132
|
+
size = _embed$embedData.size;
|
|
133
|
+
var _figureType = getFigureType(size, align);
|
|
134
|
+
return (0, _jsxRuntime.jsxs)(_Figure.Figure, {
|
|
135
|
+
type: _figureType,
|
|
136
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
137
|
+
className: "c-figure__img",
|
|
138
|
+
children: (0, _jsxRuntime.jsx)("img", {
|
|
139
|
+
alt: t('image.error.url'),
|
|
140
|
+
src: errorSvgSrc
|
|
141
|
+
})
|
|
142
|
+
}), (0, _jsxRuntime.jsx)("figcaption", {
|
|
143
|
+
children: t('image.error.caption')
|
|
144
|
+
})]
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
var data = embed.data,
|
|
148
|
+
embedData = embed.embedData,
|
|
149
|
+
seq = embed.seq;
|
|
150
|
+
var authors = getLicenseCredits(data.copyright);
|
|
151
|
+
var altText = embedData.alt || '';
|
|
152
|
+
var caption = embedData.caption || '';
|
|
153
|
+
var license = (0, _licenses.getLicenseByAbbreviation)(data.copyright.license.license, i18n.language);
|
|
154
|
+
var figureType = getFigureType(embedData.size, embedData.align);
|
|
155
|
+
var sizes = getSizes(embedData.size, embedData.align);
|
|
156
|
+
var focalPoint = getFocalPoint(embedData);
|
|
157
|
+
var crop = getCrop(embedData);
|
|
158
|
+
var contributors = (0, _licenses.getGroupedContributorDescriptionList)(data.copyright, i18n.language).map(function (item) {
|
|
159
|
+
return {
|
|
160
|
+
name: item.description,
|
|
161
|
+
type: item.label
|
|
162
|
+
};
|
|
163
|
+
});
|
|
164
|
+
var figureId = "figure-".concat(seq, "-").concat(data.id);
|
|
165
|
+
var creators = authors.creators,
|
|
166
|
+
rightsholders = authors.rightsholders,
|
|
167
|
+
processors = authors.processors;
|
|
168
|
+
var captionAuthors = creators.length || rightsholders.length ? [].concat(_toConsumableArray(creators), _toConsumableArray(rightsholders)) : processors;
|
|
169
|
+
return (0, _jsxRuntime.jsxs)(_Figure.Figure, {
|
|
170
|
+
id: figureId,
|
|
171
|
+
type: imageSizes ? undefined : figureType,
|
|
172
|
+
className: imageSizes ? 'c-figure--right expanded' : '',
|
|
173
|
+
children: [(0, _jsxRuntime.jsx)(ImageWrapper, {
|
|
174
|
+
src: data.imageUrl,
|
|
175
|
+
crop: crop,
|
|
176
|
+
size: embedData.size,
|
|
177
|
+
children: (0, _jsxRuntime.jsx)(_Image["default"], {
|
|
178
|
+
focalPoint: focalPoint,
|
|
179
|
+
contentType: data.contentType,
|
|
180
|
+
crop: crop,
|
|
181
|
+
sizes: imageSizes !== null && imageSizes !== void 0 ? imageSizes : sizes,
|
|
182
|
+
alt: altText,
|
|
183
|
+
src: data.imageUrl,
|
|
184
|
+
expandButton: (0, _jsxRuntime.jsx)(ExpandButton, {
|
|
185
|
+
size: embedData.size,
|
|
186
|
+
expanded: !!imageSizes,
|
|
187
|
+
bylineHidden: isBylineHidden,
|
|
188
|
+
onExpand: function onExpand() {
|
|
189
|
+
return setImageSizes(function (p) {
|
|
190
|
+
return p ? undefined : expandedSizes;
|
|
191
|
+
});
|
|
192
|
+
},
|
|
193
|
+
onHideByline: function onHideByline() {
|
|
194
|
+
return setIsBylineHidden(function (p) {
|
|
195
|
+
return !p;
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
})
|
|
199
|
+
})
|
|
200
|
+
}), previewAlt ? (0, _jsxRuntime.jsx)(StyledSpan, {
|
|
201
|
+
children: "Alt: ".concat(embedData.alt)
|
|
202
|
+
}) : null, (0, _jsxRuntime.jsx)(_Figure.FigureCaption, {
|
|
203
|
+
hideFigcaption: isSmall(embedData.size) || isBylineHidden,
|
|
204
|
+
figureId: figureId,
|
|
205
|
+
id: figureId,
|
|
206
|
+
caption: caption,
|
|
207
|
+
reuseLabel: t('image.reuse'),
|
|
208
|
+
modalButton: (0, _jsxRuntime.jsx)(_button.ButtonV2, {
|
|
209
|
+
shape: "pill",
|
|
210
|
+
variant: "outline",
|
|
211
|
+
size: "small",
|
|
212
|
+
onClick: function onClick() {
|
|
213
|
+
return setIsOpen(true);
|
|
214
|
+
},
|
|
215
|
+
children: t('image.reuse')
|
|
216
|
+
}),
|
|
217
|
+
licenseRights: license.rights,
|
|
218
|
+
authors: captionAuthors,
|
|
219
|
+
locale: i18n.language,
|
|
220
|
+
children: (0, _jsxRuntime.jsx)(_modal.ModalV2, {
|
|
221
|
+
controlled: true,
|
|
222
|
+
isOpen: isOpen,
|
|
223
|
+
onClose: function onClose() {
|
|
224
|
+
return setIsOpen(false);
|
|
225
|
+
},
|
|
226
|
+
labelledBy: "license-dialog-rules-heading",
|
|
227
|
+
children: function children(close) {
|
|
228
|
+
return (0, _jsxRuntime.jsx)(_FigureLicenseDialogContent.FigureLicenseDialogContent, {
|
|
229
|
+
title: data.title.title,
|
|
230
|
+
license: license,
|
|
231
|
+
onClose: close,
|
|
232
|
+
authors: contributors,
|
|
233
|
+
origin: data.copyright.origin,
|
|
234
|
+
locale: i18n.language,
|
|
235
|
+
type: "image",
|
|
236
|
+
children: (0, _jsxRuntime.jsx)(ImageLicenseButtons, {
|
|
237
|
+
articlePath: articlePath,
|
|
238
|
+
title: data.title.title,
|
|
239
|
+
imageUrl: data.imageUrl,
|
|
240
|
+
copyright: data.copyright
|
|
241
|
+
})
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
})
|
|
245
|
+
})]
|
|
246
|
+
});
|
|
247
|
+
};
|
|
248
|
+
var hideByline = function hideByline(size) {
|
|
249
|
+
return !!size && size.endsWith('-hide-byline');
|
|
250
|
+
};
|
|
251
|
+
var ImageLicenseButtons = function ImageLicenseButtons(_ref2) {
|
|
252
|
+
var _copyright$license, _copyright$license2, _copyright$license3;
|
|
253
|
+
var imageUrl = _ref2.imageUrl,
|
|
254
|
+
title = _ref2.title,
|
|
255
|
+
articlePath = _ref2.articlePath,
|
|
256
|
+
copyright = _ref2.copyright;
|
|
257
|
+
var _useTranslation2 = (0, _reactI18next.useTranslation)(),
|
|
258
|
+
t = _useTranslation2.t,
|
|
259
|
+
i18n = _useTranslation2.i18n;
|
|
260
|
+
if (!(copyright !== null && copyright !== void 0 && (_copyright$license = copyright.license) !== null && _copyright$license !== void 0 && _copyright$license.license) || (copyright === null || copyright === void 0 ? void 0 : (_copyright$license2 = copyright.license) === null || _copyright$license2 === void 0 ? void 0 : _copyright$license2.license) === 'COPYRIGHTED') return null;
|
|
261
|
+
var copyString = (0, _licenses.figureApa7CopyString)(title, undefined, imageUrl, articlePath, copyright, copyright === null || copyright === void 0 ? void 0 : (_copyright$license3 = copyright.license) === null || _copyright$license3 === void 0 ? void 0 : _copyright$license3.license, '', t, i18n.language);
|
|
262
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
263
|
+
children: [(0, _jsxRuntime.jsx)(_button.CopyButton, {
|
|
264
|
+
variant: "outline",
|
|
265
|
+
onClick: function onClick() {
|
|
266
|
+
return navigator.clipboard.writeText(copyString);
|
|
267
|
+
},
|
|
268
|
+
copyNode: t('license.hasCopiedTitle'),
|
|
269
|
+
"aria-live": "assertive",
|
|
270
|
+
children: t('license.copyTitle')
|
|
271
|
+
}), (0, _jsxRuntime.jsx)(_safelink.SafeLinkButton, {
|
|
272
|
+
to: "".concat(imageUrl, "?download=true"),
|
|
273
|
+
download: true,
|
|
274
|
+
variant: "outline",
|
|
275
|
+
children: t('image.download')
|
|
276
|
+
})]
|
|
277
|
+
});
|
|
278
|
+
};
|
|
279
|
+
exports.ImageLicenseButtons = ImageLicenseButtons;
|
|
280
|
+
var ImageWrapper = function ImageWrapper(_ref3) {
|
|
281
|
+
var src = _ref3.src,
|
|
282
|
+
crop = _ref3.crop,
|
|
283
|
+
size = _ref3.size,
|
|
284
|
+
children = _ref3.children;
|
|
285
|
+
var _useTranslation3 = (0, _reactI18next.useTranslation)(),
|
|
286
|
+
t = _useTranslation3.t;
|
|
287
|
+
if (isSmall(size) || hideByline(size)) {
|
|
288
|
+
return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
|
|
289
|
+
children: children
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
return (0, _jsxRuntime.jsx)(_Image.ImageLink, {
|
|
293
|
+
src: src,
|
|
294
|
+
crop: crop,
|
|
295
|
+
"aria-label": t('license.images.itemImage.ariaLabel'),
|
|
296
|
+
children: children
|
|
297
|
+
});
|
|
298
|
+
};
|
|
299
|
+
var ExpandButton = function ExpandButton(_ref4) {
|
|
300
|
+
var size = _ref4.size,
|
|
301
|
+
expanded = _ref4.expanded,
|
|
302
|
+
bylineHidden = _ref4.bylineHidden,
|
|
303
|
+
onExpand = _ref4.onExpand,
|
|
304
|
+
onHideByline = _ref4.onHideByline;
|
|
305
|
+
var _useTranslation4 = (0, _reactI18next.useTranslation)(),
|
|
306
|
+
t = _useTranslation4.t;
|
|
307
|
+
if (isSmall(size)) {
|
|
308
|
+
return (0, _jsxRuntime.jsx)("button", {
|
|
309
|
+
type: "button",
|
|
310
|
+
className: "c-figure__fullscreen-btn",
|
|
311
|
+
"aria-label": t("license.images.itemImage.zoom".concat(expanded ? 'Out' : '', "ImageButtonLabel")),
|
|
312
|
+
onClick: onExpand,
|
|
313
|
+
children: expanded ? (0, _jsxRuntime.jsx)(_common.ArrowCollapse, {}) : (0, _jsxRuntime.jsx)(_action.ExpandTwoArrows, {})
|
|
314
|
+
});
|
|
315
|
+
} else if (hideByline(size)) {
|
|
316
|
+
return (0, _jsxRuntime.jsx)("button", {
|
|
317
|
+
type: "button",
|
|
318
|
+
className: "c-figure__show-byline-btn",
|
|
319
|
+
"aria-label": t("license.images.itemImage.".concat(bylineHidden ? 'expandByline' : 'minimizeByline')),
|
|
320
|
+
onClick: onHideByline,
|
|
321
|
+
children: bylineHidden ? (0, _jsxRuntime.jsx)(_common.ChevronDown, {}) : (0, _jsxRuntime.jsx)(_common.ChevronUp, {})
|
|
322
|
+
});
|
|
323
|
+
} else return null;
|
|
324
|
+
};
|
|
325
|
+
var _default = ImageEmbed;
|
|
326
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2023-present, NDLA.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
import { RelatedContentMetaData } from '@ndla/types-embed';
|
|
9
|
+
interface Props {
|
|
10
|
+
embed: RelatedContentMetaData;
|
|
11
|
+
isOembed?: boolean;
|
|
12
|
+
subject?: string;
|
|
13
|
+
ndlaFrontendDomain?: string;
|
|
14
|
+
}
|
|
15
|
+
declare const RelatedContentEmbed: ({ embed, isOembed, subject, ndlaFrontendDomain }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
16
|
+
export default RelatedContentEmbed;
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
var _reactI18next = require("react-i18next");
|
|
8
|
+
var _ContentType = require("../model/ContentType");
|
|
9
|
+
var _RelatedArticleV = require("../RelatedArticleList/RelatedArticleV2");
|
|
10
|
+
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
11
|
+
/**
|
|
12
|
+
* Copyright (c) 2023-present, NDLA.
|
|
13
|
+
*
|
|
14
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
15
|
+
* LICENSE file in the root directory of this source tree.
|
|
16
|
+
*
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
var RelatedContentEmbed = function RelatedContentEmbed(_ref) {
|
|
20
|
+
var embed = _ref.embed,
|
|
21
|
+
isOembed = _ref.isOembed,
|
|
22
|
+
subject = _ref.subject,
|
|
23
|
+
ndlaFrontendDomain = _ref.ndlaFrontendDomain;
|
|
24
|
+
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
25
|
+
t = _useTranslation.t;
|
|
26
|
+
if (embed.status === 'error') {
|
|
27
|
+
return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {});
|
|
28
|
+
}
|
|
29
|
+
var data = embed.data,
|
|
30
|
+
embedData = embed.embedData;
|
|
31
|
+
if (embedData.articleId && data) {
|
|
32
|
+
var _data$resource, _data$resource$resour, _data$resource$paths$, _data$resource2, _data$resource3, _data$article$title$t, _data$article$metaDes, _data$article$metaDes2;
|
|
33
|
+
var typeId = (_data$resource = data.resource) === null || _data$resource === void 0 ? void 0 : (_data$resource$resour = _data$resource.resourceTypes.find(function (rt) {
|
|
34
|
+
return _ContentType.contentTypeMapping[rt.id];
|
|
35
|
+
})) === null || _data$resource$resour === void 0 ? void 0 : _data$resource$resour.id;
|
|
36
|
+
var type = typeId ? _ContentType.contentTypeMapping[typeId] : undefined;
|
|
37
|
+
var path = (_data$resource$paths$ = (_data$resource2 = data.resource) === null || _data$resource2 === void 0 ? void 0 : _data$resource2.paths.find(function (p) {
|
|
38
|
+
return p.split('/')[1] === (subject === null || subject === void 0 ? void 0 : subject.replace('urn:', ''));
|
|
39
|
+
})) !== null && _data$resource$paths$ !== void 0 ? _data$resource$paths$ : (_data$resource3 = data.resource) === null || _data$resource3 === void 0 ? void 0 : _data$resource3.path;
|
|
40
|
+
return (0, _jsxRuntime.jsx)(_RelatedArticleV.RelatedArticleV2, {
|
|
41
|
+
title: (_data$article$title$t = data.article.title.title) !== null && _data$article$title$t !== void 0 ? _data$article$title$t : '',
|
|
42
|
+
introduction: (_data$article$metaDes = (_data$article$metaDes2 = data.article.metaDescription) === null || _data$article$metaDes2 === void 0 ? void 0 : _data$article$metaDes2.metaDescription) !== null && _data$article$metaDes !== void 0 ? _data$article$metaDes : '',
|
|
43
|
+
target: isOembed ? '_blank' : undefined,
|
|
44
|
+
to: "".concat(ndlaFrontendDomain !== null && ndlaFrontendDomain !== void 0 ? ndlaFrontendDomain : '').concat(path !== null && path !== void 0 ? path : ''),
|
|
45
|
+
type: type
|
|
46
|
+
});
|
|
47
|
+
} else if (typeof embedData.url === 'string') {
|
|
48
|
+
var _embedData$title, _embedData$url$match;
|
|
49
|
+
return (0, _jsxRuntime.jsx)(_RelatedArticleV.RelatedArticleV2, {
|
|
50
|
+
title: (_embedData$title = embedData.title) !== null && _embedData$title !== void 0 ? _embedData$title : '',
|
|
51
|
+
introduction: "",
|
|
52
|
+
to: embedData.url,
|
|
53
|
+
target: "_blank",
|
|
54
|
+
type: 'external-learning-resources',
|
|
55
|
+
linkInfo: "".concat(t('related.linkInfo'), " ").concat(
|
|
56
|
+
// Get domain name only from url
|
|
57
|
+
((_embedData$url$match = embedData.url.match(/^(?:https?:\/\/)?(?:[^@\n]+@)?(?:www\.)?([^:/\n]+)/im)) === null || _embedData$url$match === void 0 ? void 0 : _embedData$url$match[1]) || embedData.url)
|
|
58
|
+
});
|
|
59
|
+
} else {
|
|
60
|
+
return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {});
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
var _default = RelatedContentEmbed;
|
|
64
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2023-present, NDLA.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
import { MetaData } from '@ndla/types-embed';
|
|
9
|
+
interface Props {
|
|
10
|
+
embed: MetaData<any, any>;
|
|
11
|
+
}
|
|
12
|
+
declare const UnknownEmbed: ({ embed }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
13
|
+
export default UnknownEmbed;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
+
var _reactI18next = require("react-i18next");
|
|
9
|
+
var _core = require("@ndla/core");
|
|
10
|
+
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
12
|
+
/**
|
|
13
|
+
* Copyright (c) 2023-present, NDLA.
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
var StyledSpan = /*#__PURE__*/(0, _base["default"])("span", {
|
|
21
|
+
target: "e1rt6jrv0",
|
|
22
|
+
label: "StyledSpan"
|
|
23
|
+
})("color:", _core.colors.support.red, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlVua25vd25FbWJlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUI4QiIsImZpbGUiOiJVbmtub3duRW1iZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBNZXRhRGF0YSB9IGZyb20gJ0BuZGxhL3R5cGVzLWVtYmVkJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgZW1iZWQ6IE1ldGFEYXRhPGFueSwgYW55Pjtcbn1cblxuY29uc3QgU3R5bGVkU3BhbiA9IHN0eWxlZC5zcGFuYFxuICBjb2xvcjogJHtjb2xvcnMuc3VwcG9ydC5yZWR9O1xuYDtcblxuY29uc3QgVW5rbm93bkVtYmVkID0gKHsgZW1iZWQgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gPFN0eWxlZFNwYW4+e3QoJ2VtYmVkLnVuc3VwcG9ydGVkJywgeyB0eXBlOiBlbWJlZC5yZXNvdXJjZSB9KX08L1N0eWxlZFNwYW4+O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgVW5rbm93bkVtYmVkO1xuIl19 */"));
|
|
24
|
+
var UnknownEmbed = function UnknownEmbed(_ref) {
|
|
25
|
+
var embed = _ref.embed;
|
|
26
|
+
var _useTranslation = (0, _reactI18next.useTranslation)(),
|
|
27
|
+
t = _useTranslation.t;
|
|
28
|
+
return (0, _jsxRuntime.jsx)(StyledSpan, {
|
|
29
|
+
children: t('embed.unsupported', {
|
|
30
|
+
type: embed.resource
|
|
31
|
+
})
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
var _default = UnknownEmbed;
|
|
35
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2023-present, NDLA.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the GPLv3 license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
import { ReactNode, RefAttributes } from 'react';
|
|
9
|
+
import { ConceptVisualElementMeta } from '@ndla/types-embed';
|
|
10
|
+
import { Copyright } from '../types';
|
|
11
|
+
export interface ConceptNotionData {
|
|
12
|
+
title: string;
|
|
13
|
+
content?: string;
|
|
14
|
+
articlePath?: string;
|
|
15
|
+
metaImage?: {
|
|
16
|
+
url?: string;
|
|
17
|
+
alt?: string;
|
|
18
|
+
};
|
|
19
|
+
copyright?: Copyright;
|
|
20
|
+
source?: string;
|
|
21
|
+
visualElement?: ConceptVisualElementMeta;
|
|
22
|
+
}
|
|
23
|
+
interface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {
|
|
24
|
+
className?: string;
|
|
25
|
+
closeButton?: ReactNode;
|
|
26
|
+
previewAlt?: boolean;
|
|
27
|
+
inPopover?: boolean;
|
|
28
|
+
tags?: string[];
|
|
29
|
+
subjects?: string[];
|
|
30
|
+
}
|
|
31
|
+
export declare const ConceptNotionV2: import("react").ForwardRefExoticComponent<Pick<ConceptNotionProps, "key" | "source" | "content" | "title" | "className" | "tags" | "articlePath" | "previewAlt" | "copyright" | "visualElement" | "closeButton" | "inPopover" | "subjects" | "metaImage"> & RefAttributes<HTMLDivElement>>;
|
|
32
|
+
export {};
|