@ndla/ui 4.3.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (177) hide show
  1. package/README.md +11 -11
  2. package/es/Article/Article.js +3 -7
  3. package/es/Article/ArticleByline.js +4 -4
  4. package/es/Article/ArticleNotions.js +37 -92
  5. package/es/ContentTypeBadge/ContentTypeBadge.js +10 -1
  6. package/es/FactBox/FactBox.js +36 -11
  7. package/es/Filter/FilterButtons.js +18 -17
  8. package/es/Filter/FilterCarousel.js +198 -0
  9. package/es/Masthead/Masthead.js +24 -2
  10. package/es/Notion/ConceptNotion.js +57 -0
  11. package/es/Notion/FigureNotion.js +82 -0
  12. package/es/Notion/Notion.js +122 -48
  13. package/es/Notion/NotionImage.js +47 -0
  14. package/es/Notion/NotionVisualElement.js +38 -0
  15. package/es/Notion/index.js +2 -1
  16. package/es/SearchTypeResult/ActiveFilterContent.js +17 -2
  17. package/es/SearchTypeResult/ActiveFilters.js +64 -50
  18. package/es/SearchTypeResult/PopupFilter.js +28 -125
  19. package/es/SearchTypeResult/ResultNavigation.js +41 -14
  20. package/es/SearchTypeResult/SearchFieldHeader.js +20 -41
  21. package/es/SearchTypeResult/SearchFilterContent.js +61 -0
  22. package/es/SearchTypeResult/SearchHeader.js +51 -28
  23. package/es/SearchTypeResult/SearchItem.js +64 -190
  24. package/es/SearchTypeResult/SearchItemList.js +132 -0
  25. package/es/SearchTypeResult/SearchItems.js +17 -13
  26. package/es/SearchTypeResult/SearchNotionItem.js +13 -13
  27. package/es/SearchTypeResult/SearchNotionsResult.js +16 -21
  28. package/es/SearchTypeResult/SearchTypeHeader.js +43 -26
  29. package/es/SearchTypeResult/SearchTypeResult.js +7 -5
  30. package/es/SearchTypeResult/SearchViewType.js +93 -0
  31. package/es/SearchTypeResult/components/ItemContexts.js +125 -0
  32. package/es/SearchTypeResult/components/ItemResourceHeader.js +87 -0
  33. package/es/SearchTypeResult/components/ItemTopicHeader.js +56 -0
  34. package/es/SearchTypeResult/components/SubjectFilters.js +177 -0
  35. package/es/SearchTypeResult/index.js +2 -1
  36. package/es/all.css +1 -1
  37. package/es/index-javascript.js +1 -2
  38. package/es/index.js +3 -2
  39. package/es/locale/messages-en.js +21 -6
  40. package/es/locale/messages-nb.js +21 -6
  41. package/es/locale/messages-nn.js +22 -7
  42. package/es/model/ContentType.js +2 -1
  43. package/es/shapes.js +1 -1
  44. package/lib/Article/Article.d.ts +4 -5
  45. package/lib/Article/Article.js +3 -7
  46. package/lib/Article/ArticleByline.js +4 -4
  47. package/lib/Article/ArticleNotions.d.ts +3 -8
  48. package/lib/Article/ArticleNotions.js +41 -90
  49. package/lib/ContentTypeBadge/ContentTypeBadge.d.ts +1 -0
  50. package/lib/ContentTypeBadge/ContentTypeBadge.js +14 -2
  51. package/lib/FactBox/FactBox.js +41 -8
  52. package/lib/Filter/FilterButtons.d.ts +3 -10
  53. package/lib/Filter/FilterButtons.js +19 -17
  54. package/lib/Filter/FilterCarousel.d.ts +13 -0
  55. package/lib/Filter/FilterCarousel.js +207 -0
  56. package/lib/Masthead/Masthead.js +30 -2
  57. package/lib/Notion/ConceptNotion.d.ts +25 -0
  58. package/lib/Notion/ConceptNotion.js +79 -0
  59. package/lib/Notion/FigureNotion.d.ts +23 -0
  60. package/lib/Notion/FigureNotion.js +97 -0
  61. package/lib/Notion/Notion.d.ts +24 -11
  62. package/lib/Notion/Notion.js +120 -48
  63. package/lib/Notion/NotionImage.d.ts +15 -0
  64. package/lib/Notion/NotionImage.js +63 -0
  65. package/lib/Notion/NotionVisualElement.d.ts +22 -0
  66. package/lib/Notion/NotionVisualElement.js +51 -0
  67. package/lib/Notion/index.d.ts +1 -0
  68. package/lib/Notion/index.js +8 -0
  69. package/lib/SearchTypeResult/ActiveFilterContent.js +16 -9
  70. package/lib/SearchTypeResult/ActiveFilters.d.ts +2 -1
  71. package/lib/SearchTypeResult/ActiveFilters.js +65 -50
  72. package/lib/SearchTypeResult/PopupFilter.d.ts +13 -19
  73. package/lib/SearchTypeResult/PopupFilter.js +27 -123
  74. package/lib/SearchTypeResult/ResultNavigation.d.ts +2 -2
  75. package/lib/SearchTypeResult/ResultNavigation.js +38 -14
  76. package/lib/SearchTypeResult/SearchFieldHeader.d.ts +3 -8
  77. package/lib/SearchTypeResult/SearchFieldHeader.js +18 -39
  78. package/lib/SearchTypeResult/SearchFilterContent.d.ts +16 -0
  79. package/lib/SearchTypeResult/SearchFilterContent.js +67 -0
  80. package/lib/SearchTypeResult/SearchHeader.d.ts +3 -7
  81. package/lib/SearchTypeResult/SearchHeader.js +59 -30
  82. package/lib/SearchTypeResult/SearchItem.d.ts +8 -12
  83. package/lib/SearchTypeResult/SearchItem.js +64 -187
  84. package/lib/SearchTypeResult/SearchItemList.d.ts +10 -0
  85. package/lib/SearchTypeResult/SearchItemList.js +139 -0
  86. package/lib/SearchTypeResult/SearchItems.d.ts +4 -3
  87. package/lib/SearchTypeResult/SearchItems.js +18 -13
  88. package/lib/SearchTypeResult/SearchNotionItem.js +13 -13
  89. package/lib/SearchTypeResult/SearchNotionsResult.d.ts +2 -4
  90. package/lib/SearchTypeResult/SearchNotionsResult.js +23 -23
  91. package/lib/SearchTypeResult/SearchTypeHeader.d.ts +2 -2
  92. package/lib/SearchTypeResult/SearchTypeHeader.js +40 -25
  93. package/lib/SearchTypeResult/SearchTypeResult.d.ts +7 -6
  94. package/lib/SearchTypeResult/SearchTypeResult.js +7 -5
  95. package/lib/SearchTypeResult/SearchViewType.d.ts +13 -0
  96. package/lib/SearchTypeResult/SearchViewType.js +99 -0
  97. package/lib/SearchTypeResult/components/ItemContexts.d.ts +19 -0
  98. package/lib/SearchTypeResult/components/ItemContexts.js +134 -0
  99. package/lib/SearchTypeResult/components/ItemResourceHeader.d.ts +16 -0
  100. package/lib/SearchTypeResult/components/ItemResourceHeader.js +98 -0
  101. package/lib/SearchTypeResult/components/ItemTopicHeader.d.ts +17 -0
  102. package/lib/SearchTypeResult/components/ItemTopicHeader.js +67 -0
  103. package/lib/SearchTypeResult/components/SubjectFilters.d.ts +32 -0
  104. package/lib/SearchTypeResult/components/SubjectFilters.js +192 -0
  105. package/lib/SearchTypeResult/index.d.ts +2 -1
  106. package/lib/SearchTypeResult/index.js +8 -0
  107. package/lib/all.css +1 -1
  108. package/lib/index-javascript.js +0 -20
  109. package/lib/index.d.ts +2 -1
  110. package/lib/index.js +24 -1
  111. package/lib/locale/messages-en.d.ts +16 -1
  112. package/lib/locale/messages-en.js +21 -6
  113. package/lib/locale/messages-nb.d.ts +15 -0
  114. package/lib/locale/messages-nb.js +21 -6
  115. package/lib/locale/messages-nn.d.ts +16 -1
  116. package/lib/locale/messages-nn.js +22 -7
  117. package/lib/model/ContentType.d.ts +1 -0
  118. package/lib/model/ContentType.js +4 -2
  119. package/lib/shapes.js +1 -1
  120. package/lib/types.d.ts +1 -0
  121. package/package.json +14 -15
  122. package/src/Article/Article.tsx +8 -15
  123. package/src/Article/ArticleByline.tsx +1 -1
  124. package/src/Article/ArticleNotions.tsx +13 -33
  125. package/src/ContentTypeBadge/ContentTypeBadge.tsx +8 -0
  126. package/src/ContentTypeBadge/component.content-type-badge.scss +5 -0
  127. package/src/FactBox/FactBox.tsx +22 -15
  128. package/src/Figure/component.figure.scss +1 -1
  129. package/src/Filter/FilterButtons.tsx +14 -15
  130. package/src/Filter/FilterCarousel.tsx +166 -0
  131. package/src/Masthead/Masthead.tsx +42 -18
  132. package/src/Notion/ConceptNotion.tsx +80 -0
  133. package/src/Notion/FigureNotion.tsx +86 -0
  134. package/src/Notion/Notion.tsx +205 -75
  135. package/src/Notion/NotionImage.tsx +51 -0
  136. package/src/Notion/NotionVisualElement.tsx +50 -0
  137. package/src/Notion/index.ts +1 -0
  138. package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -2
  139. package/src/SearchTypeResult/ActiveFilters.tsx +72 -38
  140. package/src/SearchTypeResult/PopupFilter.tsx +73 -146
  141. package/src/SearchTypeResult/ResultNavigation.tsx +54 -16
  142. package/src/SearchTypeResult/SearchFieldHeader.tsx +15 -40
  143. package/src/SearchTypeResult/SearchFilterContent.tsx +63 -0
  144. package/src/SearchTypeResult/SearchHeader.tsx +31 -31
  145. package/src/SearchTypeResult/SearchItem.tsx +145 -233
  146. package/src/SearchTypeResult/SearchItemList.tsx +167 -0
  147. package/src/SearchTypeResult/SearchItems.tsx +26 -19
  148. package/src/SearchTypeResult/SearchNotionItem.tsx +5 -12
  149. package/src/SearchTypeResult/SearchNotionsResult.tsx +29 -22
  150. package/src/SearchTypeResult/SearchTypeHeader.tsx +51 -33
  151. package/src/SearchTypeResult/SearchTypeResult.tsx +13 -12
  152. package/src/SearchTypeResult/SearchViewType.tsx +109 -0
  153. package/src/SearchTypeResult/components/ItemContexts.tsx +138 -0
  154. package/src/SearchTypeResult/components/ItemResourceHeader.tsx +133 -0
  155. package/src/SearchTypeResult/components/ItemTopicHeader.tsx +95 -0
  156. package/src/SearchTypeResult/components/SubjectFilters.tsx +152 -0
  157. package/src/SearchTypeResult/index.ts +9 -1
  158. package/src/index-javascript.js +0 -2
  159. package/src/index.ts +3 -0
  160. package/src/locale/messages-en.ts +19 -4
  161. package/src/locale/messages-nb.ts +19 -4
  162. package/src/locale/messages-nn.ts +20 -5
  163. package/src/model/ContentType.ts +1 -0
  164. package/src/shapes.js +1 -0
  165. package/src/types.ts +1 -0
  166. package/es/Embedded/Facebook.js +0 -19
  167. package/es/Embedded/FacebookPage.js +0 -22
  168. package/es/Embedded/Twitter.js +0 -121
  169. package/es/Embedded/index.js +0 -3
  170. package/lib/Embedded/Facebook.js +0 -32
  171. package/lib/Embedded/FacebookPage.js +0 -35
  172. package/lib/Embedded/Twitter.js +0 -132
  173. package/lib/Embedded/index.js +0 -31
  174. package/src/Embedded/Facebook.jsx +0 -17
  175. package/src/Embedded/FacebookPage.jsx +0 -24
  176. package/src/Embedded/Twitter.jsx +0 -71
  177. package/src/Embedded/index.js +0 -3
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
@@ -11,86 +13,156 @@ var _reactI18next = require("react-i18next");
11
13
 
12
14
  var _htmlReactParser = _interopRequireDefault(require("html-react-parser"));
13
15
 
14
- var _react = _interopRequireDefault(require("react"));
16
+ var _react = _interopRequireWildcard(require("react"));
17
+
18
+ var _core = require("@emotion/core");
15
19
 
16
20
  var _button = _interopRequireDefault(require("@ndla/button"));
17
21
 
18
- var _util = require("@ndla/util");
22
+ var _core2 = require("@ndla/core");
23
+
24
+ var _action = require("@ndla/icons/action");
19
25
 
20
- var _core = require("@ndla/core");
26
+ var _common = require("@ndla/icons/common");
21
27
 
22
- var _licenses = require("@ndla/licenses");
28
+ var _Image = require("../Image");
23
29
 
24
- var _core2 = require("@emotion/core");
30
+ function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
31
+
32
+ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (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; }
25
33
 
26
34
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
27
35
 
36
+ function _templateObject2() {
37
+ var data = _taggedTemplateLiteral(["\n 0% {\n opacity: 1;\n height: auto;\n }\n 100% {\n opacity: 0;\n height:0;\n overflow: hidden;\n }\n"]);
38
+
39
+ _templateObject2 = function _templateObject2() {
40
+ return data;
41
+ };
42
+
43
+ return data;
44
+ }
45
+
46
+ function _templateObject() {
47
+ var data = _taggedTemplateLiteral(["\n 0% {\n opacity: 0;\n height: auto;\n }\n 100% {\n opacity: 1;\n }\n"]);
48
+
49
+ _templateObject = function _templateObject() {
50
+ return data;
51
+ };
52
+
53
+ return data;
54
+ }
55
+
56
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
57
+
28
58
  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)."; }
29
59
 
30
60
  var NotionContainer = (0, _styledBase["default"])("div", {
31
61
  target: "eztjhst0",
32
62
  label: "NotionContainer"
33
- })("border-bottom:1px solid ", _core.colors.brand.greyLighter, ";margin-bottom:3.5rem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVWtDIiwiZmlsZSI6Ik5vdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEhUTUxSZWFjdFBhcnNlciBmcm9tICdodG1sLXJlYWN0LXBhcnNlcic7XG5pbXBvcnQgUmVhY3QsIHsgTW91c2VFdmVudEhhbmRsZXIsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCdXR0b24gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IGpvaW5BcnJheVdpdGhDb25qdW5jdGlvbiB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuaW1wb3J0IHsgY29sb3JzLCBmb250cyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgZ2V0TGljZW5zZUJ5QWJicmV2aWF0aW9uIH0gZnJvbSAnQG5kbGEvbGljZW5zZXMnO1xuaW1wb3J0IHsgTG9jYWxlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBOb3Rpb25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXJ9O1xuICBtYXJnaW4tYm90dG9tOiAzLjVyZW07XG5gO1xuXG5jb25zdCBBdXRob3JzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBtYXJnaW46IDAgMCAxLjVyZW07XG4gIGZvbnQtc2l6ZTogMC44NzVyZW07XG5cbiAgcCB7XG4gICAgbWFyZ2luOiAwO1xuXG4gICAgJjpub3QoOm9ubHktY2hpbGQpIHtcbiAgICAgIG1hcmdpbi1yaWdodDogMXJlbTtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IExhYmVsc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtc2l6ZTogMC44NzVyZW07XG4gIG1hcmdpbi1ib3R0b206IDFyZW07XG5cbiAgcCB7XG4gICAgbWFyZ2luOiAwO1xuICB9XG5cbiAgPiA6bm90KDpsYXN0LWNoaWxkKSB7XG4gICAgbWFyZ2luLXJpZ2h0OiAwLjVyZW07XG4gIH1cbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLnNwYW5gXG4gICR7Zm9udHMuc2l6ZXMoJzE0cHgnLCAnMjRweCcpfTtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMCAwLjI1cmVtO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlc3R9O1xuICB2ZXJ0aWNhbC1hbGlnbjogY2VudGVyO1xuYDtcblxuZXhwb3J0IHR5cGUgTm90aW9uUHJvcHMgPSB7XG4gIGF1dGhvcnM/OiB7IG5hbWU6IHN0cmluZyB9W107XG4gIGlkOiBzdHJpbmc7XG4gIGxhYmVscz86IHN0cmluZ1tdO1xuICBsaWNlbnNlPzogc3RyaW5nO1xuICBsb2NhbGU/OiBMb2NhbGU7XG4gIG1lZGlhPzogUmVhY3ROb2RlO1xuICBvblJlZmVyZW5jZUNsaWNrPzogTW91c2VFdmVudEhhbmRsZXI8SFRNTEJ1dHRvbkVsZW1lbnQ+O1xuICByZW5kZXJNYXJrZG93bj86ICh0ZXh0OiBzdHJpbmcpID0+IHN0cmluZztcbiAgdGV4dDogUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xufTtcblxuY29uc3QgTm90aW9uID0gKHtcbiAgYXV0aG9ycyA9IFtdLFxuICBpZCxcbiAgbGFiZWxzID0gW10sXG4gIGxpY2Vuc2UsXG4gIGxvY2FsZSxcbiAgbWVkaWEsXG4gIG9uUmVmZXJlbmNlQ2xpY2ssXG4gIHJlbmRlck1hcmtkb3duLFxuICB0ZXh0LFxuICB0aXRsZSxcbn06IE5vdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8Tm90aW9uQ29udGFpbmVyPlxuICAgICAgPGRpdj5cbiAgICAgICAge0hUTUxSZWFjdFBhcnNlcihcbiAgICAgICAgICByZW5kZXJNYXJrZG93biA/IHJlbmRlck1hcmtkb3duKGAqKiR7dGl0bGV9KiogXFx1MjAxMyAke3RleHR9YCkgOiBgPGI+JHt0aXRsZX08L2I+IFxcdTIwMTMgJHt0ZXh0fWAsXG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHshIW1lZGlhICYmIG1lZGlhfVxuICAgICAgeyEhYXV0aG9ycy5sZW5ndGggJiYgKFxuICAgICAgICA8QXV0aG9yc0NvbnRhaW5lcj5cbiAgICAgICAgICA8cD5cbiAgICAgICAgICAgIHt0KCdhcnRpY2xlLndyaXR0ZW5CeScsIHtcbiAgICAgICAgICAgICAgYXV0aG9yczogam9pbkFycmF5V2l0aENvbmp1bmN0aW9uKFxuICAgICAgICAgICAgICAgIGF1dGhvcnMubWFwKChhdXRob3IpID0+IGF1dGhvci5uYW1lKSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICBjb25qdW5jdGlvbjogYCAke3QoJ2FydGljbGUuY29uanVuY3Rpb24nKX0gYCxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICB7bGljZW5zZSAmJiBgICgke2dldExpY2Vuc2VCeUFiYnJldmlhdGlvbihsaWNlbnNlLCBsb2NhbGUpLmFiYnJldmlhdGlvbn0pYH1cbiAgICAgICAgICA8L3A+XG4gICAgICAgICAge29uUmVmZXJlbmNlQ2xpY2sgJiYgKFxuICAgICAgICAgICAgPEJ1dHRvbiBsaW5rIG9uQ2xpY2s9e29uUmVmZXJlbmNlQ2xpY2t9PlxuICAgICAgICAgICAgICB7dCgnYXJ0aWNsZS5jaXRlTm90aW9uJyl9XG4gICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICApfVxuICAgICAgICA8L0F1dGhvcnNDb250YWluZXI+XG4gICAgICApfVxuICAgICAgeyEhbGFiZWxzLmxlbmd0aCAmJiAoXG4gICAgICAgIDxMYWJlbHNDb250YWluZXI+XG4gICAgICAgICAgPHA+e3QoJ3NlYXJjaFBhZ2UucmVzdWx0VHlwZS5ub3Rpb25MYWJlbHMnKX08L3A+XG4gICAgICAgICAge2xhYmVscy5tYXAoKGxhYmVsLCBpKSA9PiAoXG4gICAgICAgICAgICA8TGFiZWwga2V5PXtgbm90aW9uLSR7aWR9LWxhYmVsLSR7aSArIDF9YH0+e2xhYmVsfTwvTGFiZWw+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGFiZWxzQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICA8L05vdGlvbkNvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE5vdGlvbjtcbiJdfQ== */"));
34
- var AuthorsContainer = (0, _styledBase["default"])("div", {
63
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAmBkC","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
64
+ var ContentWrapper = (0, _styledBase["default"])("div", {
35
65
  target: "eztjhst1",
36
- label: "AuthorsContainer"
66
+ label: "ContentWrapper"
67
+ })(_core2.mq.range({
68
+ until: _core2.breakpoints.tabletWide
69
+ }), "{display:flex;flex-direction:column-reverse;}.c-figure{margin:0;position:relative !important;left:0 !important;width:25% !important;padding:0 0 0 20px;float:right;&.expanded{width:100% !important;padding:0;margin-bottom:", _core2.spacing.normal, ";}", _core2.mq.range({
70
+ until: _core2.breakpoints.tabletWide
71
+ }), "{width:100% !important;padding:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAqBiC","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
72
+ var TextWrapper = (0, _styledBase["default"])("div", {
73
+ target: "eztjhst2",
74
+ label: "TextWrapper"
75
+ })("width:75%;", _core2.mq.range({
76
+ until: _core2.breakpoints.tabletWide
77
+ }), "{width:100%;}font-family:", _core2.fonts.serif, ";", _core2.fonts.sizes('18px', '28px'), ";", ContentWrapper, " .c-figure.expanded + &{width:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA4C8B","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
78
+ var ImageElement = (0, _styledBase["default"])("img", {
79
+ target: "eztjhst3",
80
+ label: "ImageElement"
81
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAwD+B","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */");
82
+ var fadeInMediaKeyframe = (0, _core.keyframes)(_templateObject());
83
+ var fadeOutMediaKeyframe = (0, _core.keyframes)(_templateObject2());
84
+ var ImageWrapper = (0, _styledBase["default"])("div", {
85
+ target: "eztjhst4",
86
+ label: "ImageWrapper"
87
+ })("float:right;width:25%;padding-left:", _core2.spacing.normal, ";position:relative;", _core2.mq.range({
88
+ until: _core2.breakpoints.tabletWide
89
+ }), "{width:100%;padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+E+B","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
90
+ var ExpandVisualElementButton = ( /*#__PURE__*/0, _styledBase["default"])(_button["default"], {
91
+ target: "eztjhst5",
92
+ label: "ExpandVisualElementButton"
93
+ })("position:absolute;right:8px;bottom:8px;transition:all ", _core2.animations.durations.normal, ";&,&:focus,&:active{background-color:rgba(255,255,255,0.65);}color:", _core2.colors.brand.primary, ";border-radius:50%;border:0;width:40px;height:40px;display:inline-flex;justify-content:center;align-items:center;svg{transition:transform ", _core2.animations.durations.normal, " ease-out;}", ContentWrapper, ":hover &{background-color:#fff;svg{transform:scale(1.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA2FgD","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
94
+ var ExpandIcon = (0, _styledBase["default"])("span", {
95
+ target: "eztjhst6",
96
+ label: "ExpandIcon"
97
+ })(ExpandVisualElementButton, ".expanded &{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0H8B","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
98
+ var CollapseIcon = (0, _styledBase["default"])("span", {
99
+ target: "eztjhst7",
100
+ label: "CollapseIcon"
101
+ })("display:none;", ExpandVisualElementButton, ".expanded &{display:inline-block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA+HgC","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
102
+ var ClearWrapper = (0, _styledBase["default"])("div", {
103
+ target: "eztjhst8",
104
+ label: "ClearWrapper"
37
105
  })(process.env.NODE_ENV === "production" ? {
38
- name: "agxie1",
39
- styles: "display:flex;flex-wrap:wrap;margin:0 0 1.5rem;font-size:0.875rem;p{margin:0;&:not(:only-child){margin-right:1rem;}}"
106
+ name: "1xa411s",
107
+ styles: "clear:both;"
40
108
  } : {
41
- name: "agxie1",
42
- styles: "display:flex;flex-wrap:wrap;margin:0 0 1.5rem;font-size:0.875rem;p{margin:0;&:not(:only-child){margin-right:1rem;}}",
43
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1DIiwiZmlsZSI6Ik5vdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEhUTUxSZWFjdFBhcnNlciBmcm9tICdodG1sLXJlYWN0LXBhcnNlcic7XG5pbXBvcnQgUmVhY3QsIHsgTW91c2VFdmVudEhhbmRsZXIsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCdXR0b24gZnJvbSAnQG5kbGEvYnV0dG9uJztcbmltcG9ydCB7IGpvaW5BcnJheVdpdGhDb25qdW5jdGlvbiB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuaW1wb3J0IHsgY29sb3JzLCBmb250cyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgZ2V0TGljZW5zZUJ5QWJicmV2aWF0aW9uIH0gZnJvbSAnQG5kbGEvbGljZW5zZXMnO1xuaW1wb3J0IHsgTG9jYWxlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBOb3Rpb25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXJ9O1xuICBtYXJnaW4tYm90dG9tOiAzLjVyZW07XG5gO1xuXG5jb25zdCBBdXRob3JzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBtYXJnaW46IDAgMCAxLjVyZW07XG4gIGZvbnQtc2l6ZTogMC44NzVyZW07XG5cbiAgcCB7XG4gICAgbWFyZ2luOiAwO1xuXG4gICAgJjpub3QoOm9ubHktY2hpbGQpIHtcbiAgICAgIG1hcmdpbi1yaWdodDogMXJlbTtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IExhYmVsc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtc2l6ZTogMC44NzVyZW07XG4gIG1hcmdpbi1ib3R0b206IDFyZW07XG5cbiAgcCB7XG4gICAgbWFyZ2luOiAwO1xuICB9XG5cbiAgPiA6bm90KDpsYXN0LWNoaWxkKSB7XG4gICAgbWFyZ2luLXJpZ2h0OiAwLjVyZW07XG4gIH1cbmA7XG5cbmNvbnN0IExhYmVsID0gc3R5bGVkLnNwYW5gXG4gICR7Zm9udHMuc2l6ZXMoJzE0cHgnLCAnMjRweCcpfTtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMCAwLjI1cmVtO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlc3R9O1xuICB2ZXJ0aWNhbC1hbGlnbjogY2VudGVyO1xuYDtcblxuZXhwb3J0IHR5cGUgTm90aW9uUHJvcHMgPSB7XG4gIGF1dGhvcnM/OiB7IG5hbWU6IHN0cmluZyB9W107XG4gIGlkOiBzdHJpbmc7XG4gIGxhYmVscz86IHN0cmluZ1tdO1xuICBsaWNlbnNlPzogc3RyaW5nO1xuICBsb2NhbGU/OiBMb2NhbGU7XG4gIG1lZGlhPzogUmVhY3ROb2RlO1xuICBvblJlZmVyZW5jZUNsaWNrPzogTW91c2VFdmVudEhhbmRsZXI8SFRNTEJ1dHRvbkVsZW1lbnQ+O1xuICByZW5kZXJNYXJrZG93bj86ICh0ZXh0OiBzdHJpbmcpID0+IHN0cmluZztcbiAgdGV4dDogUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xufTtcblxuY29uc3QgTm90aW9uID0gKHtcbiAgYXV0aG9ycyA9IFtdLFxuICBpZCxcbiAgbGFiZWxzID0gW10sXG4gIGxpY2Vuc2UsXG4gIGxvY2FsZSxcbiAgbWVkaWEsXG4gIG9uUmVmZXJlbmNlQ2xpY2ssXG4gIHJlbmRlck1hcmtkb3duLFxuICB0ZXh0LFxuICB0aXRsZSxcbn06IE5vdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8Tm90aW9uQ29udGFpbmVyPlxuICAgICAgPGRpdj5cbiAgICAgICAge0hUTUxSZWFjdFBhcnNlcihcbiAgICAgICAgICByZW5kZXJNYXJrZG93biA/IHJlbmRlck1hcmtkb3duKGAqKiR7dGl0bGV9KiogXFx1MjAxMyAke3RleHR9YCkgOiBgPGI+JHt0aXRsZX08L2I+IFxcdTIwMTMgJHt0ZXh0fWAsXG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHshIW1lZGlhICYmIG1lZGlhfVxuICAgICAgeyEhYXV0aG9ycy5sZW5ndGggJiYgKFxuICAgICAgICA8QXV0aG9yc0NvbnRhaW5lcj5cbiAgICAgICAgICA8cD5cbiAgICAgICAgICAgIHt0KCdhcnRpY2xlLndyaXR0ZW5CeScsIHtcbiAgICAgICAgICAgICAgYXV0aG9yczogam9pbkFycmF5V2l0aENvbmp1bmN0aW9uKFxuICAgICAgICAgICAgICAgIGF1dGhvcnMubWFwKChhdXRob3IpID0+IGF1dGhvci5uYW1lKSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICBjb25qdW5jdGlvbjogYCAke3QoJ2FydGljbGUuY29uanVuY3Rpb24nKX0gYCxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICB7bGljZW5zZSAmJiBgICgke2dldExpY2Vuc2VCeUFiYnJldmlhdGlvbihsaWNlbnNlLCBsb2NhbGUpLmFiYnJldmlhdGlvbn0pYH1cbiAgICAgICAgICA8L3A+XG4gICAgICAgICAge29uUmVmZXJlbmNlQ2xpY2sgJiYgKFxuICAgICAgICAgICAgPEJ1dHRvbiBsaW5rIG9uQ2xpY2s9e29uUmVmZXJlbmNlQ2xpY2t9PlxuICAgICAgICAgICAgICB7dCgnYXJ0aWNsZS5jaXRlTm90aW9uJyl9XG4gICAgICAgICAgICA8L0J1dHRvbj5cbiAgICAgICAgICApfVxuICAgICAgICA8L0F1dGhvcnNDb250YWluZXI+XG4gICAgICApfVxuICAgICAgeyEhbGFiZWxzLmxlbmd0aCAmJiAoXG4gICAgICAgIDxMYWJlbHNDb250YWluZXI+XG4gICAgICAgICAgPHA+e3QoJ3NlYXJjaFBhZ2UucmVzdWx0VHlwZS5ub3Rpb25MYWJlbHMnKX08L3A+XG4gICAgICAgICAge2xhYmVscy5tYXAoKGxhYmVsLCBpKSA9PiAoXG4gICAgICAgICAgICA8TGFiZWwga2V5PXtgbm90aW9uLSR7aWR9LWxhYmVsLSR7aSArIDF9YH0+e2xhYmVsfTwvTGFiZWw+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGFiZWxzQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICA8L05vdGlvbkNvbnRhaW5lcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE5vdGlvbjtcbiJdfQ== */",
109
+ name: "1xa411s",
110
+ styles: "clear:both;",
111
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AAsI+B","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */",
44
112
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
45
113
  });
114
+ var MediaContainer = (0, _styledBase["default"])("div", {
115
+ target: "eztjhst9",
116
+ label: "MediaContainer"
117
+ })("opacity:0;height:0;overflow:hidden;&.expanded{animation-name:", fadeInMediaKeyframe, ";animation-duration:2.8s;opacity:1;height:auto;}&.fadeOut{animation-name:", fadeOutMediaKeyframe, ";animation-duration:2.8s;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0IiC","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
46
118
  var LabelsContainer = (0, _styledBase["default"])("div", {
47
- target: "eztjhst2",
119
+ target: "eztjhst10",
48
120
  label: "LabelsContainer"
49
- })(process.env.NODE_ENV === "production" ? {
50
- name: "zrluiy",
51
- styles: "display:flex;align-items:center;font-size:0.875rem;margin-bottom:1rem;p{margin:0;}>:not(:last-child){margin-right:0.5rem;}"
52
- } : {
53
- name: "zrluiy",
54
- styles: "display:flex;align-items:center;font-size:0.875rem;margin-bottom:1rem;p{margin:0;}>:not(:last-child){margin-right:0.5rem;}",
55
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJOb3Rpb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBIVE1MUmVhY3RQYXJzZXIgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IFJlYWN0LCB7IE1vdXNlRXZlbnRIYW5kbGVyLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBqb2luQXJyYXlXaXRoQ29uanVuY3Rpb24gfSBmcm9tICdAbmRsYS91dGlsJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IGdldExpY2Vuc2VCeUFiYnJldmlhdGlvbiB9IGZyb20gJ0BuZGxhL2xpY2Vuc2VzJztcbmltcG9ydCB7IExvY2FsZSB9IGZyb20gJy4uL3R5cGVzJztcblxuY29uc3QgTm90aW9uQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodGVyfTtcbiAgbWFyZ2luLWJvdHRvbTogMy41cmVtO1xuYDtcblxuY29uc3QgQXV0aG9yc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWFyZ2luOiAwIDAgMS41cmVtO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcblxuICAgICY6bm90KDpvbmx5LWNoaWxkKSB7XG4gICAgICBtYXJnaW4tcmlnaHQ6IDFyZW07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBMYWJlbHNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuICBtYXJnaW4tYm90dG9tOiAxcmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuXG4gID4gOm5vdCg6bGFzdC1jaGlsZCkge1xuICAgIG1hcmdpbi1yaWdodDogMC41cmVtO1xuICB9XG5gO1xuXG5jb25zdCBMYWJlbCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzI0cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIHBhZGRpbmc6IDAgMC4yNXJlbTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgdmVydGljYWwtYWxpZ246IGNlbnRlcjtcbmA7XG5cbmV4cG9ydCB0eXBlIE5vdGlvblByb3BzID0ge1xuICBhdXRob3JzPzogeyBuYW1lOiBzdHJpbmcgfVtdO1xuICBpZDogc3RyaW5nO1xuICBsYWJlbHM/OiBzdHJpbmdbXTtcbiAgbGljZW5zZT86IHN0cmluZztcbiAgbG9jYWxlPzogTG9jYWxlO1xuICBtZWRpYT86IFJlYWN0Tm9kZTtcbiAgb25SZWZlcmVuY2VDbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxCdXR0b25FbGVtZW50PjtcbiAgcmVuZGVyTWFya2Rvd24/OiAodGV4dDogc3RyaW5nKSA9PiBzdHJpbmc7XG4gIHRleHQ6IFJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbn07XG5cbmNvbnN0IE5vdGlvbiA9ICh7XG4gIGF1dGhvcnMgPSBbXSxcbiAgaWQsXG4gIGxhYmVscyA9IFtdLFxuICBsaWNlbnNlLFxuICBsb2NhbGUsXG4gIG1lZGlhLFxuICBvblJlZmVyZW5jZUNsaWNrLFxuICByZW5kZXJNYXJrZG93bixcbiAgdGV4dCxcbiAgdGl0bGUsXG59OiBOb3Rpb25Qcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPE5vdGlvbkNvbnRhaW5lcj5cbiAgICAgIDxkaXY+XG4gICAgICAgIHtIVE1MUmVhY3RQYXJzZXIoXG4gICAgICAgICAgcmVuZGVyTWFya2Rvd24gPyByZW5kZXJNYXJrZG93bihgKioke3RpdGxlfSoqIFxcdTIwMTMgJHt0ZXh0fWApIDogYDxiPiR7dGl0bGV9PC9iPiBcXHUyMDEzICR7dGV4dH1gLFxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgICB7ISFtZWRpYSAmJiBtZWRpYX1cbiAgICAgIHshIWF1dGhvcnMubGVuZ3RoICYmIChcbiAgICAgICAgPEF1dGhvcnNDb250YWluZXI+XG4gICAgICAgICAgPHA+XG4gICAgICAgICAgICB7dCgnYXJ0aWNsZS53cml0dGVuQnknLCB7XG4gICAgICAgICAgICAgIGF1dGhvcnM6IGpvaW5BcnJheVdpdGhDb25qdW5jdGlvbihcbiAgICAgICAgICAgICAgICBhdXRob3JzLm1hcCgoYXV0aG9yKSA9PiBhdXRob3IubmFtZSksXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgY29uanVuY3Rpb246IGAgJHt0KCdhcnRpY2xlLmNvbmp1bmN0aW9uJyl9IGAsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAge2xpY2Vuc2UgJiYgYCAoJHtnZXRMaWNlbnNlQnlBYmJyZXZpYXRpb24obGljZW5zZSwgbG9jYWxlKS5hYmJyZXZpYXRpb259KWB9XG4gICAgICAgICAgPC9wPlxuICAgICAgICAgIHtvblJlZmVyZW5jZUNsaWNrICYmIChcbiAgICAgICAgICAgIDxCdXR0b24gbGluayBvbkNsaWNrPXtvblJlZmVyZW5jZUNsaWNrfT5cbiAgICAgICAgICAgICAge3QoJ2FydGljbGUuY2l0ZU5vdGlvbicpfVxuICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9BdXRob3JzQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICAgIHshIWxhYmVscy5sZW5ndGggJiYgKFxuICAgICAgICA8TGFiZWxzQ29udGFpbmVyPlxuICAgICAgICAgIDxwPnt0KCdzZWFyY2hQYWdlLnJlc3VsdFR5cGUubm90aW9uTGFiZWxzJyl9PC9wPlxuICAgICAgICAgIHtsYWJlbHMubWFwKChsYWJlbCwgaSkgPT4gKFxuICAgICAgICAgICAgPExhYmVsIGtleT17YG5vdGlvbi0ke2lkfS1sYWJlbC0ke2kgKyAxfWB9PntsYWJlbH08L0xhYmVsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L0xhYmVsc0NvbnRhaW5lcj5cbiAgICAgICl9XG4gICAgPC9Ob3Rpb25Db250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBOb3Rpb247XG4iXX0= */",
56
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
- });
58
- var Label = (0, _styledBase["default"])("span", {
59
- target: "eztjhst3",
60
- label: "Label"
61
- })(_core.fonts.sizes('14px', '24px'), ";font-weight:600;padding:0 0.25rem;background-color:", _core.colors.brand.greyLightest, ";vertical-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkN5QiIsImZpbGUiOiJOb3Rpb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBIVE1MUmVhY3RQYXJzZXIgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IFJlYWN0LCB7IE1vdXNlRXZlbnRIYW5kbGVyLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBqb2luQXJyYXlXaXRoQ29uanVuY3Rpb24gfSBmcm9tICdAbmRsYS91dGlsJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IGdldExpY2Vuc2VCeUFiYnJldmlhdGlvbiB9IGZyb20gJ0BuZGxhL2xpY2Vuc2VzJztcbmltcG9ydCB7IExvY2FsZSB9IGZyb20gJy4uL3R5cGVzJztcblxuY29uc3QgTm90aW9uQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodGVyfTtcbiAgbWFyZ2luLWJvdHRvbTogMy41cmVtO1xuYDtcblxuY29uc3QgQXV0aG9yc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWFyZ2luOiAwIDAgMS41cmVtO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcblxuICAgICY6bm90KDpvbmx5LWNoaWxkKSB7XG4gICAgICBtYXJnaW4tcmlnaHQ6IDFyZW07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBMYWJlbHNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuICBtYXJnaW4tYm90dG9tOiAxcmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuXG4gID4gOm5vdCg6bGFzdC1jaGlsZCkge1xuICAgIG1hcmdpbi1yaWdodDogMC41cmVtO1xuICB9XG5gO1xuXG5jb25zdCBMYWJlbCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzI0cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIHBhZGRpbmc6IDAgMC4yNXJlbTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgdmVydGljYWwtYWxpZ246IGNlbnRlcjtcbmA7XG5cbmV4cG9ydCB0eXBlIE5vdGlvblByb3BzID0ge1xuICBhdXRob3JzPzogeyBuYW1lOiBzdHJpbmcgfVtdO1xuICBpZDogc3RyaW5nO1xuICBsYWJlbHM/OiBzdHJpbmdbXTtcbiAgbGljZW5zZT86IHN0cmluZztcbiAgbG9jYWxlPzogTG9jYWxlO1xuICBtZWRpYT86IFJlYWN0Tm9kZTtcbiAgb25SZWZlcmVuY2VDbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxCdXR0b25FbGVtZW50PjtcbiAgcmVuZGVyTWFya2Rvd24/OiAodGV4dDogc3RyaW5nKSA9PiBzdHJpbmc7XG4gIHRleHQ6IFJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbn07XG5cbmNvbnN0IE5vdGlvbiA9ICh7XG4gIGF1dGhvcnMgPSBbXSxcbiAgaWQsXG4gIGxhYmVscyA9IFtdLFxuICBsaWNlbnNlLFxuICBsb2NhbGUsXG4gIG1lZGlhLFxuICBvblJlZmVyZW5jZUNsaWNrLFxuICByZW5kZXJNYXJrZG93bixcbiAgdGV4dCxcbiAgdGl0bGUsXG59OiBOb3Rpb25Qcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPE5vdGlvbkNvbnRhaW5lcj5cbiAgICAgIDxkaXY+XG4gICAgICAgIHtIVE1MUmVhY3RQYXJzZXIoXG4gICAgICAgICAgcmVuZGVyTWFya2Rvd24gPyByZW5kZXJNYXJrZG93bihgKioke3RpdGxlfSoqIFxcdTIwMTMgJHt0ZXh0fWApIDogYDxiPiR7dGl0bGV9PC9iPiBcXHUyMDEzICR7dGV4dH1gLFxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgICB7ISFtZWRpYSAmJiBtZWRpYX1cbiAgICAgIHshIWF1dGhvcnMubGVuZ3RoICYmIChcbiAgICAgICAgPEF1dGhvcnNDb250YWluZXI+XG4gICAgICAgICAgPHA+XG4gICAgICAgICAgICB7dCgnYXJ0aWNsZS53cml0dGVuQnknLCB7XG4gICAgICAgICAgICAgIGF1dGhvcnM6IGpvaW5BcnJheVdpdGhDb25qdW5jdGlvbihcbiAgICAgICAgICAgICAgICBhdXRob3JzLm1hcCgoYXV0aG9yKSA9PiBhdXRob3IubmFtZSksXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgY29uanVuY3Rpb246IGAgJHt0KCdhcnRpY2xlLmNvbmp1bmN0aW9uJyl9IGAsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAge2xpY2Vuc2UgJiYgYCAoJHtnZXRMaWNlbnNlQnlBYmJyZXZpYXRpb24obGljZW5zZSwgbG9jYWxlKS5hYmJyZXZpYXRpb259KWB9XG4gICAgICAgICAgPC9wPlxuICAgICAgICAgIHtvblJlZmVyZW5jZUNsaWNrICYmIChcbiAgICAgICAgICAgIDxCdXR0b24gbGluayBvbkNsaWNrPXtvblJlZmVyZW5jZUNsaWNrfT5cbiAgICAgICAgICAgICAge3QoJ2FydGljbGUuY2l0ZU5vdGlvbicpfVxuICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9BdXRob3JzQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICAgIHshIWxhYmVscy5sZW5ndGggJiYgKFxuICAgICAgICA8TGFiZWxzQ29udGFpbmVyPlxuICAgICAgICAgIDxwPnt0KCdzZWFyY2hQYWdlLnJlc3VsdFR5cGUubm90aW9uTGFiZWxzJyl9PC9wPlxuICAgICAgICAgIHtsYWJlbHMubWFwKChsYWJlbCwgaSkgPT4gKFxuICAgICAgICAgICAgPExhYmVsIGtleT17YG5vdGlvbi0ke2lkfS1sYWJlbC0ke2kgKyAxfWB9PntsYWJlbH08L0xhYmVsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L0xhYmVsc0NvbnRhaW5lcj5cbiAgICAgICl9XG4gICAgPC9Ob3Rpb25Db250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBOb3Rpb247XG4iXX0= */"));
121
+ })("display:flex;align-items:center;", _core2.fonts.sizes('14px', '24px'), ";font-family:", _core2.fonts.sans, ";margin:", _core2.spacing.small, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Notion.tsx"],"names":[],"mappings":"AA0JkC","file":"Notion.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport HTMLReactParser from 'html-react-parser';\nimport React, { Fragment, ReactNode } from 'react';\nimport { keyframes } from '@emotion/core';\nimport Button from '@ndla/button';\nimport { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { CursorClick } from '@ndla/icons/action';\nimport { Play, ArrowCollapse } from '@ndla/icons/common';\nimport { ImageCrop, ImageFocalPoint, makeSrcQueryString } from '../Image';\n\nconst NotionContainer = styled.div``;\n\nconst ContentWrapper = styled.div`\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    display: flex;\n    flex-direction: column-reverse;\n  }\n  .c-figure {\n    margin: 0;\n    position: relative !important;\n    left: 0 !important;\n    width: 25% !important;\n    padding: 0 0 0 20px;\n    float: right;\n    &.expanded {\n      width: 100% !important;\n      padding: 0;\n      margin-bottom: ${spacing.normal};\n    }\n    ${mq.range({ until: breakpoints.tabletWide })} {\n      width: 100% !important;\n      padding: 0;\n    }\n  }\n`;\nconst TextWrapper = styled.div`\n  width: 75%;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n  }\n  font-family: ${fonts.serif};\n  ${fonts.sizes('18px', '28px')};\n  ${ContentWrapper} .c-figure.expanded + & {\n    width: 100%;\n  }\n`;\n\nconst ImageElement = styled.img``;\n\nconst fadeInMediaKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    height: auto;\n  }\n  100% {\n    opacity: 1;\n  }\n`;\nconst fadeOutMediaKeyframe = keyframes`\n  0% {\n    opacity: 1;\n    height: auto;\n  }\n  100% {\n    opacity: 0;\n    height:0;\n    overflow: hidden;\n  }\n`;\n\nconst ImageWrapper = styled.div`\n  float: right;\n  width: 25%;\n  padding-left: ${spacing.normal};\n  position: relative;\n\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    width: 100%;\n    padding-left: 0;\n  }\n`;\n\nconst ExpandVisualElementButton = styled(Button)`\n  position: absolute;\n  right: 8px;\n  bottom: 8px;\n  transition: all ${animations.durations.normal};\n  &,\n  &:focus,\n  &:active {\n    background-color: rgba(255, 255, 255, 0.65);\n  }\n\n  color: ${colors.brand.primary};\n  border-radius: 50%;\n  border: 0;\n  width: 40px;\n  height: 40px;\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n\n  svg {\n    transition: transform ${animations.durations.normal} ease-out;\n  }\n  ${ContentWrapper}:hover & {\n    background-color: #fff;\n    svg {\n      transform: scale(1.2);\n    }\n  }\n`;\n\nconst ExpandIcon = styled.span`\n  ${ExpandVisualElementButton}.expanded & {\n    display: none;\n  }\n`;\nconst CollapseIcon = styled.span`\n  display: none;\n  ${ExpandVisualElementButton}.expanded & {\n    display: inline-block;\n  }\n`;\n\nconst ClearWrapper = styled.div`\n  clear: both;\n`;\n\nconst MediaContainer = styled.div`\n  opacity: 0;\n  height: 0;\n  overflow: hidden;\n  &.expanded {\n    animation-name: ${fadeInMediaKeyframe};\n    animation-duration: 2.8s;\n    opacity: 1;\n    height: auto;\n  }\n  &.fadeOut {\n    animation-name: ${fadeOutMediaKeyframe};\n    animation-duration: 2.8s;\n  }\n`;\n\nconst LabelsContainer = styled.div`\n  display: flex;\n  align-items: center;\n  ${fonts.sizes('14px', '24px')};\n  font-family: ${fonts.sans};\n  margin: ${spacing.small} 0;\n`;\n\ntype VisualElementProps = {\n  type: 'video' | 'other';\n  element: ReactNode;\n  metaImage?: {\n    url: string;\n    alt: string;\n    crop?: ImageCrop;\n    focalPoint?: ImageFocalPoint;\n  };\n};\n\nexport type NotionProps = {\n  id: string | number;\n  labels?: string[];\n  renderMarkdown?: (text: string) => string;\n  text: ReactNode;\n  title: string;\n  visualElement?: VisualElementProps;\n  imageElement?: ReactNode;\n  children?: ReactNode;\n};\n\nconst Notion = ({\n  id,\n  labels = [],\n  renderMarkdown,\n  text,\n  title,\n  visualElement,\n  imageElement,\n  children,\n}: NotionProps) => {\n  const { t } = useTranslation();\n\n  return (\n    <NotionContainer>\n      {visualElement && <MediaContainer id={`notion-media-${id}`}>{visualElement.element}</MediaContainer>}\n      <ContentWrapper>\n        {imageElement}\n        {visualElement && visualElement.metaImage && (\n          <ImageWrapper>\n            <ImageElement\n              src={`${visualElement.metaImage.url}?${makeSrcQueryString(\n                400,\n                visualElement.metaImage.crop,\n                visualElement.metaImage.focalPoint,\n              )}`}\n              alt={visualElement.metaImage.alt}\n            />\n            <ExpandVisualElementButton\n              stripped\n              data-notion-expand-media={true}\n              data-notion-media-id={`notion-media-${id}`}>\n              <ExpandIcon>\n                {visualElement.type === 'video' && <Play style={{ width: '24px', height: '24px' }} />}\n                {visualElement.type === 'other' && <CursorClick style={{ width: '24px', height: '24px' }} />}\n              </ExpandIcon>\n              <CollapseIcon>\n                <ArrowCollapse style={{ width: '24px', height: '24px' }} />\n              </CollapseIcon>\n            </ExpandVisualElementButton>\n          </ImageWrapper>\n        )}\n        <TextWrapper>\n          {HTMLReactParser(\n            renderMarkdown ? renderMarkdown(`**${title}** \\u2013 ${text}`) : `<b>${title}</b> \\u2013 ${text}`,\n          )}\n          {!!labels.length && (\n            <LabelsContainer>\n              {t('searchPage.resultType.notionLabels')}\n              {labels.map((label, i) => (\n                <Fragment key={`notion-${id}-label-${i + 1}`}>\n                  {' '}\n                  {label}\n                  {i < labels?.length - 1 && <> &#8226;</>}\n                </Fragment>\n              ))}\n            </LabelsContainer>\n          )}\n        </TextWrapper>\n        <ClearWrapper />\n      </ContentWrapper>\n      {children}\n    </NotionContainer>\n  );\n};\n\nexport default Notion;\n"]} */"));
62
122
 
63
123
  var Notion = function Notion(_ref) {
64
- var _ref$authors = _ref.authors,
65
- authors = _ref$authors === void 0 ? [] : _ref$authors,
66
- id = _ref.id,
124
+ var id = _ref.id,
67
125
  _ref$labels = _ref.labels,
68
126
  labels = _ref$labels === void 0 ? [] : _ref$labels,
69
- license = _ref.license,
70
- locale = _ref.locale,
71
- media = _ref.media,
72
- onReferenceClick = _ref.onReferenceClick,
73
127
  renderMarkdown = _ref.renderMarkdown,
74
128
  text = _ref.text,
75
- title = _ref.title;
129
+ title = _ref.title,
130
+ visualElement = _ref.visualElement,
131
+ imageElement = _ref.imageElement,
132
+ children = _ref.children;
76
133
 
77
134
  var _useTranslation = (0, _reactI18next.useTranslation)(),
78
135
  t = _useTranslation.t;
79
136
 
80
- return (0, _core2.jsx)(NotionContainer, null, (0, _core2.jsx)("div", null, (0, _htmlReactParser["default"])(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text))), !!media && media, !!authors.length && (0, _core2.jsx)(AuthorsContainer, null, (0, _core2.jsx)("p", null, t('article.writtenBy', {
81
- authors: (0, _util.joinArrayWithConjunction)(authors.map(function (author) {
82
- return author.name;
83
- }), {
84
- conjunction: " ".concat(t('article.conjunction'), " ")
85
- })
86
- }), license && " (".concat((0, _licenses.getLicenseByAbbreviation)(license, locale).abbreviation, ")")), onReferenceClick && (0, _core2.jsx)(_button["default"], {
87
- link: true,
88
- onClick: onReferenceClick
89
- }, t('article.citeNotion'))), !!labels.length && (0, _core2.jsx)(LabelsContainer, null, (0, _core2.jsx)("p", null, t('searchPage.resultType.notionLabels')), labels.map(function (label, i) {
90
- return (0, _core2.jsx)(Label, {
137
+ return (0, _core.jsx)(NotionContainer, null, visualElement && (0, _core.jsx)(MediaContainer, {
138
+ id: "notion-media-".concat(id)
139
+ }, visualElement.element), (0, _core.jsx)(ContentWrapper, null, imageElement, visualElement && visualElement.metaImage && (0, _core.jsx)(ImageWrapper, null, (0, _core.jsx)(ImageElement, {
140
+ src: "".concat(visualElement.metaImage.url, "?").concat((0, _Image.makeSrcQueryString)(400, visualElement.metaImage.crop, visualElement.metaImage.focalPoint)),
141
+ alt: visualElement.metaImage.alt
142
+ }), (0, _core.jsx)(ExpandVisualElementButton, {
143
+ stripped: true,
144
+ "data-notion-expand-media": true,
145
+ "data-notion-media-id": "notion-media-".concat(id)
146
+ }, (0, _core.jsx)(ExpandIcon, null, visualElement.type === 'video' && (0, _core.jsx)(_common.Play, {
147
+ style: {
148
+ width: '24px',
149
+ height: '24px'
150
+ }
151
+ }), visualElement.type === 'other' && (0, _core.jsx)(_action.CursorClick, {
152
+ style: {
153
+ width: '24px',
154
+ height: '24px'
155
+ }
156
+ })), (0, _core.jsx)(CollapseIcon, null, (0, _core.jsx)(_common.ArrowCollapse, {
157
+ style: {
158
+ width: '24px',
159
+ height: '24px'
160
+ }
161
+ })))), (0, _core.jsx)(TextWrapper, null, (0, _htmlReactParser["default"])(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text)), !!labels.length && (0, _core.jsx)(LabelsContainer, null, t('searchPage.resultType.notionLabels'), labels.map(function (label, i) {
162
+ return (0, _core.jsx)(_react.Fragment, {
91
163
  key: "notion-".concat(id, "-label-").concat(i + 1)
92
- }, label);
93
- })));
164
+ }, ' ', label, i < (labels === null || labels === void 0 ? void 0 : labels.length) - 1 && (0, _core.jsx)(_react["default"].Fragment, null, " \u2022"));
165
+ }))), (0, _core.jsx)(ClearWrapper, null)), children);
94
166
  };
95
167
 
96
168
  var _default = Notion;
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Copyright (c) 2022-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
+ import { Copyright } from '../types';
8
+ interface Props {
9
+ id: string;
10
+ src: string;
11
+ alt: string;
12
+ imageCopyright?: Partial<Copyright>;
13
+ }
14
+ export declare const NotionImage: ({ id, src, alt, imageCopyright }: Props) => JSX.Element;
15
+ export {};
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NotionImage = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _reactI18next = require("react-i18next");
11
+
12
+ var _ = require("..");
13
+
14
+ var _FigureNotion = _interopRequireDefault(require("./FigureNotion"));
15
+
16
+ var _core = require("@emotion/core");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
+
20
+ /**
21
+ * Copyright (c) 2022-present, NDLA.
22
+ *
23
+ * This source code is licensed under the GPLv3 license found in the
24
+ * LICENSE file in the root directory of this source tree. *
25
+ */
26
+ var NotionImage = function NotionImage(_ref) {
27
+ var _imageCopyright$licen, _imageCopyright$licen2;
28
+
29
+ var id = _ref.id,
30
+ src = _ref.src,
31
+ alt = _ref.alt,
32
+ imageCopyright = _ref.imageCopyright;
33
+
34
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
35
+ t = _useTranslation.t;
36
+
37
+ var imageId = "image-".concat(id);
38
+ var imageFigureId = "image-figure-".concat(id);
39
+ return (0, _core.jsx)(_FigureNotion["default"], {
40
+ hideFigCaption: true,
41
+ figureId: imageFigureId,
42
+ id: imageId,
43
+ title: alt,
44
+ copyright: imageCopyright,
45
+ licenseString: (_imageCopyright$licen = imageCopyright === null || imageCopyright === void 0 ? void 0 : (_imageCopyright$licen2 = imageCopyright.license) === null || _imageCopyright$licen2 === void 0 ? void 0 : _imageCopyright$licen2.license) !== null && _imageCopyright$licen !== void 0 ? _imageCopyright$licen : '',
46
+ type: 'image'
47
+ }, function (_ref2) {
48
+ var typeClass = _ref2.typeClass;
49
+ return (0, _core.jsx)(_.Image, {
50
+ alt: alt,
51
+ src: src,
52
+ expandButton: (0, _core.jsx)(_.FigureExpandButton, {
53
+ typeClass: typeClass,
54
+ messages: {
55
+ zoomImageButtonLabel: t('license.images.itemImage.zoomImageButtonLabel'),
56
+ zoomOutImageButtonLabel: t('license.image.itemImage.zoomOutImageButtonLabel')
57
+ }
58
+ })
59
+ });
60
+ });
61
+ };
62
+
63
+ exports.NotionImage = NotionImage;
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Copyright (c) 2022-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
+ import { Copyright } from '../types';
8
+ export declare type NotionVisualElementType = {
9
+ resource?: string;
10
+ title?: string;
11
+ url?: string;
12
+ copyright?: Partial<Copyright>;
13
+ image?: {
14
+ src: string;
15
+ alt?: string;
16
+ };
17
+ };
18
+ interface Props {
19
+ visualElement: NotionVisualElementType;
20
+ }
21
+ declare const NotionVisualElement: ({ visualElement }: Props) => JSX.Element;
22
+ export default NotionVisualElement;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _FigureNotion = _interopRequireDefault(require("./FigureNotion"));
11
+
12
+ var _core = require("@emotion/core");
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
15
+
16
+ /**
17
+ * Copyright (c) 2022-present, NDLA.
18
+ *
19
+ * This source code is licensed under the GPLv3 license found in the
20
+ * LICENSE file in the root directory of this source tree. *
21
+ */
22
+ var supportedEmbedTypes = ['brightcove', 'h5p'];
23
+
24
+ var NotionVisualElement = function NotionVisualElement(_ref) {
25
+ var _visualElement$title, _visualElement$copyri, _visualElement$copyri2, _visualElement$copyri3;
26
+
27
+ var visualElement = _ref.visualElement;
28
+ var id = '1';
29
+ var figureId = 'figure-1';
30
+
31
+ if (!visualElement.resource || !supportedEmbedTypes.includes(visualElement.resource)) {
32
+ return (0, _core.jsx)("p", null, "Embed type is not supported!");
33
+ }
34
+
35
+ var type = visualElement.resource === 'brightcove' ? 'video' : 'h5p';
36
+ return (0, _core.jsx)(_FigureNotion["default"], {
37
+ resizeIframe: true,
38
+ id: id,
39
+ figureId: figureId,
40
+ title: (_visualElement$title = visualElement.title) !== null && _visualElement$title !== void 0 ? _visualElement$title : '',
41
+ copyright: visualElement.copyright,
42
+ licenseString: (_visualElement$copyri = (_visualElement$copyri2 = visualElement.copyright) === null || _visualElement$copyri2 === void 0 ? void 0 : (_visualElement$copyri3 = _visualElement$copyri2.license) === null || _visualElement$copyri3 === void 0 ? void 0 : _visualElement$copyri3.license) !== null && _visualElement$copyri !== void 0 ? _visualElement$copyri : '',
43
+ type: type
44
+ }, (0, _core.jsx)("iframe", {
45
+ title: visualElement.title,
46
+ src: visualElement.url
47
+ }));
48
+ };
49
+
50
+ var _default = NotionVisualElement;
51
+ exports["default"] = _default;
@@ -1 +1,2 @@
1
1
  export { default as Notion } from './Notion';
2
+ export { default as ConceptNotion } from './ConceptNotion';