@ndla/ui 4.3.2 → 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 (162) 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.js +3 -2
  38. package/es/locale/messages-en.js +20 -5
  39. package/es/locale/messages-nb.js +21 -6
  40. package/es/locale/messages-nn.js +21 -6
  41. package/es/model/ContentType.js +2 -1
  42. package/es/shapes.js +1 -1
  43. package/lib/Article/Article.d.ts +4 -5
  44. package/lib/Article/Article.js +3 -7
  45. package/lib/Article/ArticleByline.js +4 -4
  46. package/lib/Article/ArticleNotions.d.ts +3 -8
  47. package/lib/Article/ArticleNotions.js +41 -90
  48. package/lib/ContentTypeBadge/ContentTypeBadge.d.ts +1 -0
  49. package/lib/ContentTypeBadge/ContentTypeBadge.js +14 -2
  50. package/lib/FactBox/FactBox.js +41 -8
  51. package/lib/Filter/FilterButtons.d.ts +3 -10
  52. package/lib/Filter/FilterButtons.js +19 -17
  53. package/lib/Filter/FilterCarousel.d.ts +13 -0
  54. package/lib/Filter/FilterCarousel.js +207 -0
  55. package/lib/Masthead/Masthead.js +30 -2
  56. package/lib/Notion/ConceptNotion.d.ts +25 -0
  57. package/lib/Notion/ConceptNotion.js +79 -0
  58. package/lib/Notion/FigureNotion.d.ts +23 -0
  59. package/lib/Notion/FigureNotion.js +97 -0
  60. package/lib/Notion/Notion.d.ts +24 -11
  61. package/lib/Notion/Notion.js +120 -48
  62. package/lib/Notion/NotionImage.d.ts +15 -0
  63. package/lib/Notion/NotionImage.js +63 -0
  64. package/lib/Notion/NotionVisualElement.d.ts +22 -0
  65. package/lib/Notion/NotionVisualElement.js +51 -0
  66. package/lib/Notion/index.d.ts +1 -0
  67. package/lib/Notion/index.js +8 -0
  68. package/lib/SearchTypeResult/ActiveFilterContent.js +16 -9
  69. package/lib/SearchTypeResult/ActiveFilters.d.ts +2 -1
  70. package/lib/SearchTypeResult/ActiveFilters.js +65 -50
  71. package/lib/SearchTypeResult/PopupFilter.d.ts +13 -19
  72. package/lib/SearchTypeResult/PopupFilter.js +27 -123
  73. package/lib/SearchTypeResult/ResultNavigation.d.ts +2 -2
  74. package/lib/SearchTypeResult/ResultNavigation.js +38 -14
  75. package/lib/SearchTypeResult/SearchFieldHeader.d.ts +3 -8
  76. package/lib/SearchTypeResult/SearchFieldHeader.js +18 -39
  77. package/lib/SearchTypeResult/SearchFilterContent.d.ts +16 -0
  78. package/lib/SearchTypeResult/SearchFilterContent.js +67 -0
  79. package/lib/SearchTypeResult/SearchHeader.d.ts +3 -7
  80. package/lib/SearchTypeResult/SearchHeader.js +59 -30
  81. package/lib/SearchTypeResult/SearchItem.d.ts +8 -12
  82. package/lib/SearchTypeResult/SearchItem.js +64 -187
  83. package/lib/SearchTypeResult/SearchItemList.d.ts +10 -0
  84. package/lib/SearchTypeResult/SearchItemList.js +139 -0
  85. package/lib/SearchTypeResult/SearchItems.d.ts +4 -3
  86. package/lib/SearchTypeResult/SearchItems.js +18 -13
  87. package/lib/SearchTypeResult/SearchNotionItem.js +13 -13
  88. package/lib/SearchTypeResult/SearchNotionsResult.d.ts +2 -4
  89. package/lib/SearchTypeResult/SearchNotionsResult.js +23 -23
  90. package/lib/SearchTypeResult/SearchTypeHeader.d.ts +2 -2
  91. package/lib/SearchTypeResult/SearchTypeHeader.js +40 -25
  92. package/lib/SearchTypeResult/SearchTypeResult.d.ts +7 -6
  93. package/lib/SearchTypeResult/SearchTypeResult.js +7 -5
  94. package/lib/SearchTypeResult/SearchViewType.d.ts +13 -0
  95. package/lib/SearchTypeResult/SearchViewType.js +99 -0
  96. package/lib/SearchTypeResult/components/ItemContexts.d.ts +19 -0
  97. package/lib/SearchTypeResult/components/ItemContexts.js +134 -0
  98. package/lib/SearchTypeResult/components/ItemResourceHeader.d.ts +16 -0
  99. package/lib/SearchTypeResult/components/ItemResourceHeader.js +98 -0
  100. package/lib/SearchTypeResult/components/ItemTopicHeader.d.ts +17 -0
  101. package/lib/SearchTypeResult/components/ItemTopicHeader.js +67 -0
  102. package/lib/SearchTypeResult/components/SubjectFilters.d.ts +32 -0
  103. package/lib/SearchTypeResult/components/SubjectFilters.js +192 -0
  104. package/lib/SearchTypeResult/index.d.ts +2 -1
  105. package/lib/SearchTypeResult/index.js +8 -0
  106. package/lib/all.css +1 -1
  107. package/lib/index.d.ts +2 -1
  108. package/lib/index.js +24 -1
  109. package/lib/locale/messages-en.d.ts +16 -1
  110. package/lib/locale/messages-en.js +20 -5
  111. package/lib/locale/messages-nb.d.ts +15 -0
  112. package/lib/locale/messages-nb.js +21 -6
  113. package/lib/locale/messages-nn.d.ts +16 -1
  114. package/lib/locale/messages-nn.js +21 -6
  115. package/lib/model/ContentType.d.ts +1 -0
  116. package/lib/model/ContentType.js +4 -2
  117. package/lib/shapes.js +1 -1
  118. package/lib/types.d.ts +1 -0
  119. package/package.json +14 -14
  120. package/src/Article/Article.tsx +8 -15
  121. package/src/Article/ArticleByline.tsx +1 -1
  122. package/src/Article/ArticleNotions.tsx +13 -33
  123. package/src/ContentTypeBadge/ContentTypeBadge.tsx +8 -0
  124. package/src/ContentTypeBadge/component.content-type-badge.scss +5 -0
  125. package/src/FactBox/FactBox.tsx +22 -15
  126. package/src/Figure/component.figure.scss +1 -1
  127. package/src/Filter/FilterButtons.tsx +14 -15
  128. package/src/Filter/FilterCarousel.tsx +166 -0
  129. package/src/Masthead/Masthead.tsx +42 -18
  130. package/src/Notion/ConceptNotion.tsx +80 -0
  131. package/src/Notion/FigureNotion.tsx +86 -0
  132. package/src/Notion/Notion.tsx +205 -75
  133. package/src/Notion/NotionImage.tsx +51 -0
  134. package/src/Notion/NotionVisualElement.tsx +50 -0
  135. package/src/Notion/index.ts +1 -0
  136. package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -2
  137. package/src/SearchTypeResult/ActiveFilters.tsx +72 -38
  138. package/src/SearchTypeResult/PopupFilter.tsx +73 -146
  139. package/src/SearchTypeResult/ResultNavigation.tsx +54 -16
  140. package/src/SearchTypeResult/SearchFieldHeader.tsx +15 -40
  141. package/src/SearchTypeResult/SearchFilterContent.tsx +63 -0
  142. package/src/SearchTypeResult/SearchHeader.tsx +31 -31
  143. package/src/SearchTypeResult/SearchItem.tsx +145 -233
  144. package/src/SearchTypeResult/SearchItemList.tsx +167 -0
  145. package/src/SearchTypeResult/SearchItems.tsx +26 -19
  146. package/src/SearchTypeResult/SearchNotionItem.tsx +5 -12
  147. package/src/SearchTypeResult/SearchNotionsResult.tsx +29 -22
  148. package/src/SearchTypeResult/SearchTypeHeader.tsx +51 -33
  149. package/src/SearchTypeResult/SearchTypeResult.tsx +13 -12
  150. package/src/SearchTypeResult/SearchViewType.tsx +109 -0
  151. package/src/SearchTypeResult/components/ItemContexts.tsx +138 -0
  152. package/src/SearchTypeResult/components/ItemResourceHeader.tsx +133 -0
  153. package/src/SearchTypeResult/components/ItemTopicHeader.tsx +95 -0
  154. package/src/SearchTypeResult/components/SubjectFilters.tsx +152 -0
  155. package/src/SearchTypeResult/index.ts +9 -1
  156. package/src/index.ts +3 -0
  157. package/src/locale/messages-en.ts +18 -3
  158. package/src/locale/messages-nb.ts +19 -4
  159. package/src/locale/messages-nn.ts +19 -4
  160. package/src/model/ContentType.ts +1 -0
  161. package/src/shapes.js +1 -0
  162. package/src/types.ts +1 -0
@@ -1,83 +1,157 @@
1
1
  import _styled from "@emotion/styled-base";
2
2
 
3
+ function _templateObject2() {
4
+ 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"]);
5
+
6
+ _templateObject2 = function _templateObject2() {
7
+ return data;
8
+ };
9
+
10
+ return data;
11
+ }
12
+
13
+ function _templateObject() {
14
+ var data = _taggedTemplateLiteral(["\n 0% {\n opacity: 0;\n height: auto;\n }\n 100% {\n opacity: 1;\n }\n"]);
15
+
16
+ _templateObject = function _templateObject() {
17
+ return data;
18
+ };
19
+
20
+ return data;
21
+ }
22
+
23
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
24
+
3
25
  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)."; }
4
26
 
5
27
  import { useTranslation } from 'react-i18next';
6
28
  import HTMLReactParser from 'html-react-parser';
7
- import React from 'react';
29
+ import React, { Fragment } from 'react';
30
+ import { keyframes } from '@emotion/core';
8
31
  import Button from '@ndla/button';
9
- import { joinArrayWithConjunction } from '@ndla/util';
10
- import { colors, fonts } from '@ndla/core';
11
- import { getLicenseByAbbreviation } from '@ndla/licenses';
32
+ import { animations, breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
33
+ import { CursorClick } from '@ndla/icons/action';
34
+ import { Play, ArrowCollapse } from '@ndla/icons/common';
35
+ import { makeSrcQueryString } from '../Image';
12
36
  import { jsx as ___EmotionJSX } from "@emotion/core";
13
37
 
14
38
  var NotionContainer = _styled("div", {
15
39
  target: "eztjhst0",
16
40
  label: "NotionContainer"
17
- })("border-bottom:1px solid ", 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== */"));
41
+ })(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"]} */");
18
42
 
19
- var AuthorsContainer = _styled("div", {
43
+ var ContentWrapper = _styled("div", {
20
44
  target: "eztjhst1",
21
- label: "AuthorsContainer"
22
- })(process.env.NODE_ENV === "production" ? {
23
- name: "agxie1",
24
- styles: "display:flex;flex-wrap:wrap;margin:0 0 1.5rem;font-size:0.875rem;p{margin:0;&:not(:only-child){margin-right:1rem;}}"
25
- } : {
26
- name: "agxie1",
27
- styles: "display:flex;flex-wrap:wrap;margin:0 0 1.5rem;font-size:0.875rem;p{margin:0;&:not(:only-child){margin-right:1rem;}}",
28
- 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== */",
29
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
- });
45
+ label: "ContentWrapper"
46
+ })(mq.range({
47
+ until: breakpoints.tabletWide
48
+ }), "{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:", spacing.normal, ";}", mq.range({
49
+ until: breakpoints.tabletWide
50
+ }), "{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"]} */"));
31
51
 
32
- var LabelsContainer = _styled("div", {
52
+ var TextWrapper = _styled("div", {
33
53
  target: "eztjhst2",
34
- label: "LabelsContainer"
54
+ label: "TextWrapper"
55
+ })("width:75%;", mq.range({
56
+ until: breakpoints.tabletWide
57
+ }), "{width:100%;}font-family:", fonts.serif, ";", 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"]} */"));
58
+
59
+ var ImageElement = _styled("img", {
60
+ target: "eztjhst3",
61
+ label: "ImageElement"
62
+ })(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"]} */");
63
+
64
+ var fadeInMediaKeyframe = keyframes(_templateObject());
65
+ var fadeOutMediaKeyframe = keyframes(_templateObject2());
66
+
67
+ var ImageWrapper = _styled("div", {
68
+ target: "eztjhst4",
69
+ label: "ImageWrapper"
70
+ })("float:right;width:25%;padding-left:", spacing.normal, ";position:relative;", mq.range({
71
+ until: breakpoints.tabletWide
72
+ }), "{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"]} */"));
73
+
74
+ var ExpandVisualElementButton = /*#__PURE__*/_styled(Button, {
75
+ target: "eztjhst5",
76
+ label: "ExpandVisualElementButton"
77
+ })("position:absolute;right:8px;bottom:8px;transition:all ", animations.durations.normal, ";&,&:focus,&:active{background-color:rgba(255,255,255,0.65);}color:", colors.brand.primary, ";border-radius:50%;border:0;width:40px;height:40px;display:inline-flex;justify-content:center;align-items:center;svg{transition:transform ", 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"]} */"));
78
+
79
+ var ExpandIcon = _styled("span", {
80
+ target: "eztjhst6",
81
+ label: "ExpandIcon"
82
+ })(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"]} */"));
83
+
84
+ var CollapseIcon = _styled("span", {
85
+ target: "eztjhst7",
86
+ label: "CollapseIcon"
87
+ })("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"]} */"));
88
+
89
+ var ClearWrapper = _styled("div", {
90
+ target: "eztjhst8",
91
+ label: "ClearWrapper"
35
92
  })(process.env.NODE_ENV === "production" ? {
36
- name: "zrluiy",
37
- styles: "display:flex;align-items:center;font-size:0.875rem;margin-bottom:1rem;p{margin:0;}>:not(:last-child){margin-right:0.5rem;}"
93
+ name: "1xa411s",
94
+ styles: "clear:both;"
38
95
  } : {
39
- name: "zrluiy",
40
- styles: "display:flex;align-items:center;font-size:0.875rem;margin-bottom:1rem;p{margin:0;}>:not(:last-child){margin-right:0.5rem;}",
41
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5vdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJOb3Rpb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBIVE1MUmVhY3RQYXJzZXIgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IFJlYWN0LCB7IE1vdXNlRXZlbnRIYW5kbGVyLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBqb2luQXJyYXlXaXRoQ29uanVuY3Rpb24gfSBmcm9tICdAbmRsYS91dGlsJztcbmltcG9ydCB7IGNvbG9ycywgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IGdldExpY2Vuc2VCeUFiYnJldmlhdGlvbiB9IGZyb20gJ0BuZGxhL2xpY2Vuc2VzJztcbmltcG9ydCB7IExvY2FsZSB9IGZyb20gJy4uL3R5cGVzJztcblxuY29uc3QgTm90aW9uQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7Y29sb3JzLmJyYW5kLmdyZXlMaWdodGVyfTtcbiAgbWFyZ2luLWJvdHRvbTogMy41cmVtO1xuYDtcblxuY29uc3QgQXV0aG9yc0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWFyZ2luOiAwIDAgMS41cmVtO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcblxuICAgICY6bm90KDpvbmx5LWNoaWxkKSB7XG4gICAgICBtYXJnaW4tcmlnaHQ6IDFyZW07XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBMYWJlbHNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmb250LXNpemU6IDAuODc1cmVtO1xuICBtYXJnaW4tYm90dG9tOiAxcmVtO1xuXG4gIHAge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuXG4gID4gOm5vdCg6bGFzdC1jaGlsZCkge1xuICAgIG1hcmdpbi1yaWdodDogMC41cmVtO1xuICB9XG5gO1xuXG5jb25zdCBMYWJlbCA9IHN0eWxlZC5zcGFuYFxuICAke2ZvbnRzLnNpemVzKCcxNHB4JywgJzI0cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIHBhZGRpbmc6IDAgMC4yNXJlbTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgdmVydGljYWwtYWxpZ246IGNlbnRlcjtcbmA7XG5cbmV4cG9ydCB0eXBlIE5vdGlvblByb3BzID0ge1xuICBhdXRob3JzPzogeyBuYW1lOiBzdHJpbmcgfVtdO1xuICBpZDogc3RyaW5nO1xuICBsYWJlbHM/OiBzdHJpbmdbXTtcbiAgbGljZW5zZT86IHN0cmluZztcbiAgbG9jYWxlPzogTG9jYWxlO1xuICBtZWRpYT86IFJlYWN0Tm9kZTtcbiAgb25SZWZlcmVuY2VDbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxCdXR0b25FbGVtZW50PjtcbiAgcmVuZGVyTWFya2Rvd24/OiAodGV4dDogc3RyaW5nKSA9PiBzdHJpbmc7XG4gIHRleHQ6IFJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbn07XG5cbmNvbnN0IE5vdGlvbiA9ICh7XG4gIGF1dGhvcnMgPSBbXSxcbiAgaWQsXG4gIGxhYmVscyA9IFtdLFxuICBsaWNlbnNlLFxuICBsb2NhbGUsXG4gIG1lZGlhLFxuICBvblJlZmVyZW5jZUNsaWNrLFxuICByZW5kZXJNYXJrZG93bixcbiAgdGV4dCxcbiAgdGl0bGUsXG59OiBOb3Rpb25Qcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPE5vdGlvbkNvbnRhaW5lcj5cbiAgICAgIDxkaXY+XG4gICAgICAgIHtIVE1MUmVhY3RQYXJzZXIoXG4gICAgICAgICAgcmVuZGVyTWFya2Rvd24gPyByZW5kZXJNYXJrZG93bihgKioke3RpdGxlfSoqIFxcdTIwMTMgJHt0ZXh0fWApIDogYDxiPiR7dGl0bGV9PC9iPiBcXHUyMDEzICR7dGV4dH1gLFxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgICB7ISFtZWRpYSAmJiBtZWRpYX1cbiAgICAgIHshIWF1dGhvcnMubGVuZ3RoICYmIChcbiAgICAgICAgPEF1dGhvcnNDb250YWluZXI+XG4gICAgICAgICAgPHA+XG4gICAgICAgICAgICB7dCgnYXJ0aWNsZS53cml0dGVuQnknLCB7XG4gICAgICAgICAgICAgIGF1dGhvcnM6IGpvaW5BcnJheVdpdGhDb25qdW5jdGlvbihcbiAgICAgICAgICAgICAgICBhdXRob3JzLm1hcCgoYXV0aG9yKSA9PiBhdXRob3IubmFtZSksXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgY29uanVuY3Rpb246IGAgJHt0KCdhcnRpY2xlLmNvbmp1bmN0aW9uJyl9IGAsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAge2xpY2Vuc2UgJiYgYCAoJHtnZXRMaWNlbnNlQnlBYmJyZXZpYXRpb24obGljZW5zZSwgbG9jYWxlKS5hYmJyZXZpYXRpb259KWB9XG4gICAgICAgICAgPC9wPlxuICAgICAgICAgIHtvblJlZmVyZW5jZUNsaWNrICYmIChcbiAgICAgICAgICAgIDxCdXR0b24gbGluayBvbkNsaWNrPXtvblJlZmVyZW5jZUNsaWNrfT5cbiAgICAgICAgICAgICAge3QoJ2FydGljbGUuY2l0ZU5vdGlvbicpfVxuICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9BdXRob3JzQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICAgIHshIWxhYmVscy5sZW5ndGggJiYgKFxuICAgICAgICA8TGFiZWxzQ29udGFpbmVyPlxuICAgICAgICAgIDxwPnt0KCdzZWFyY2hQYWdlLnJlc3VsdFR5cGUubm90aW9uTGFiZWxzJyl9PC9wPlxuICAgICAgICAgIHtsYWJlbHMubWFwKChsYWJlbCwgaSkgPT4gKFxuICAgICAgICAgICAgPExhYmVsIGtleT17YG5vdGlvbi0ke2lkfS1sYWJlbC0ke2kgKyAxfWB9PntsYWJlbH08L0xhYmVsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L0xhYmVsc0NvbnRhaW5lcj5cbiAgICAgICl9XG4gICAgPC9Ob3Rpb25Db250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBOb3Rpb247XG4iXX0= */",
96
+ name: "1xa411s",
97
+ styles: "clear:both;",
98
+ 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"]} */",
42
99
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
100
  });
44
101
 
45
- var Label = _styled("span", {
46
- target: "eztjhst3",
47
- label: "Label"
48
- })(fonts.sizes('14px', '24px'), ";font-weight:600;padding:0 0.25rem;background-color:", 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= */"));
102
+ var MediaContainer = _styled("div", {
103
+ target: "eztjhst9",
104
+ label: "MediaContainer"
105
+ })("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"]} */"));
106
+
107
+ var LabelsContainer = _styled("div", {
108
+ target: "eztjhst10",
109
+ label: "LabelsContainer"
110
+ })("display:flex;align-items:center;", fonts.sizes('14px', '24px'), ";font-family:", fonts.sans, ";margin:", 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"]} */"));
49
111
 
50
112
  var Notion = function Notion(_ref) {
51
- var _ref$authors = _ref.authors,
52
- authors = _ref$authors === void 0 ? [] : _ref$authors,
53
- id = _ref.id,
113
+ var id = _ref.id,
54
114
  _ref$labels = _ref.labels,
55
115
  labels = _ref$labels === void 0 ? [] : _ref$labels,
56
- license = _ref.license,
57
- locale = _ref.locale,
58
- media = _ref.media,
59
- onReferenceClick = _ref.onReferenceClick,
60
116
  renderMarkdown = _ref.renderMarkdown,
61
117
  text = _ref.text,
62
- title = _ref.title;
118
+ title = _ref.title,
119
+ visualElement = _ref.visualElement,
120
+ imageElement = _ref.imageElement,
121
+ children = _ref.children;
63
122
 
64
123
  var _useTranslation = useTranslation(),
65
124
  t = _useTranslation.t;
66
125
 
67
- return ___EmotionJSX(NotionContainer, null, ___EmotionJSX("div", null, HTMLReactParser(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text))), !!media && media, !!authors.length && ___EmotionJSX(AuthorsContainer, null, ___EmotionJSX("p", null, t('article.writtenBy', {
68
- authors: joinArrayWithConjunction(authors.map(function (author) {
69
- return author.name;
70
- }), {
71
- conjunction: " ".concat(t('article.conjunction'), " ")
72
- })
73
- }), license && " (".concat(getLicenseByAbbreviation(license, locale).abbreviation, ")")), onReferenceClick && ___EmotionJSX(Button, {
74
- link: true,
75
- onClick: onReferenceClick
76
- }, t('article.citeNotion'))), !!labels.length && ___EmotionJSX(LabelsContainer, null, ___EmotionJSX("p", null, t('searchPage.resultType.notionLabels')), labels.map(function (label, i) {
77
- return ___EmotionJSX(Label, {
126
+ return ___EmotionJSX(NotionContainer, null, visualElement && ___EmotionJSX(MediaContainer, {
127
+ id: "notion-media-".concat(id)
128
+ }, visualElement.element), ___EmotionJSX(ContentWrapper, null, imageElement, visualElement && visualElement.metaImage && ___EmotionJSX(ImageWrapper, null, ___EmotionJSX(ImageElement, {
129
+ src: "".concat(visualElement.metaImage.url, "?").concat(makeSrcQueryString(400, visualElement.metaImage.crop, visualElement.metaImage.focalPoint)),
130
+ alt: visualElement.metaImage.alt
131
+ }), ___EmotionJSX(ExpandVisualElementButton, {
132
+ stripped: true,
133
+ "data-notion-expand-media": true,
134
+ "data-notion-media-id": "notion-media-".concat(id)
135
+ }, ___EmotionJSX(ExpandIcon, null, visualElement.type === 'video' && ___EmotionJSX(Play, {
136
+ style: {
137
+ width: '24px',
138
+ height: '24px'
139
+ }
140
+ }), visualElement.type === 'other' && ___EmotionJSX(CursorClick, {
141
+ style: {
142
+ width: '24px',
143
+ height: '24px'
144
+ }
145
+ })), ___EmotionJSX(CollapseIcon, null, ___EmotionJSX(ArrowCollapse, {
146
+ style: {
147
+ width: '24px',
148
+ height: '24px'
149
+ }
150
+ })))), ___EmotionJSX(TextWrapper, null, HTMLReactParser(renderMarkdown ? renderMarkdown("**".concat(title, "** \u2013 ").concat(text)) : "<b>".concat(title, "</b> \u2013 ").concat(text)), !!labels.length && ___EmotionJSX(LabelsContainer, null, t('searchPage.resultType.notionLabels'), labels.map(function (label, i) {
151
+ return ___EmotionJSX(Fragment, {
78
152
  key: "notion-".concat(id, "-label-").concat(i + 1)
79
- }, label);
80
- })));
153
+ }, ' ', label, i < (labels === null || labels === void 0 ? void 0 : labels.length) - 1 && ___EmotionJSX(React.Fragment, null, " \u2022"));
154
+ }))), ___EmotionJSX(ClearWrapper, null)), children);
81
155
  };
82
156
 
83
157
  export default Notion;
@@ -0,0 +1,47 @@
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 React from 'react';
8
+ import { useTranslation } from 'react-i18next';
9
+ import { Image, FigureExpandButton } from '..';
10
+ import FigureNotion from './FigureNotion';
11
+ import { jsx as ___EmotionJSX } from "@emotion/core";
12
+ export var NotionImage = function NotionImage(_ref) {
13
+ var _imageCopyright$licen, _imageCopyright$licen2;
14
+
15
+ var id = _ref.id,
16
+ src = _ref.src,
17
+ alt = _ref.alt,
18
+ imageCopyright = _ref.imageCopyright;
19
+
20
+ var _useTranslation = useTranslation(),
21
+ t = _useTranslation.t;
22
+
23
+ var imageId = "image-".concat(id);
24
+ var imageFigureId = "image-figure-".concat(id);
25
+ return ___EmotionJSX(FigureNotion, {
26
+ hideFigCaption: true,
27
+ figureId: imageFigureId,
28
+ id: imageId,
29
+ title: alt,
30
+ copyright: imageCopyright,
31
+ 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 : '',
32
+ type: 'image'
33
+ }, function (_ref2) {
34
+ var typeClass = _ref2.typeClass;
35
+ return ___EmotionJSX(Image, {
36
+ alt: alt,
37
+ src: src,
38
+ expandButton: ___EmotionJSX(FigureExpandButton, {
39
+ typeClass: typeClass,
40
+ messages: {
41
+ zoomImageButtonLabel: t('license.images.itemImage.zoomImageButtonLabel'),
42
+ zoomOutImageButtonLabel: t('license.image.itemImage.zoomOutImageButtonLabel')
43
+ }
44
+ })
45
+ });
46
+ });
47
+ };
@@ -0,0 +1,38 @@
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 React from 'react';
8
+ import FigureNotion from './FigureNotion';
9
+ import { jsx as ___EmotionJSX } from "@emotion/core";
10
+ var supportedEmbedTypes = ['brightcove', 'h5p'];
11
+
12
+ var NotionVisualElement = function NotionVisualElement(_ref) {
13
+ var _visualElement$title, _visualElement$copyri, _visualElement$copyri2, _visualElement$copyri3;
14
+
15
+ var visualElement = _ref.visualElement;
16
+ var id = '1';
17
+ var figureId = 'figure-1';
18
+
19
+ if (!visualElement.resource || !supportedEmbedTypes.includes(visualElement.resource)) {
20
+ return ___EmotionJSX("p", null, "Embed type is not supported!");
21
+ }
22
+
23
+ var type = visualElement.resource === 'brightcove' ? 'video' : 'h5p';
24
+ return ___EmotionJSX(FigureNotion, {
25
+ resizeIframe: true,
26
+ id: id,
27
+ figureId: figureId,
28
+ title: (_visualElement$title = visualElement.title) !== null && _visualElement$title !== void 0 ? _visualElement$title : '',
29
+ copyright: visualElement.copyright,
30
+ 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 : '',
31
+ type: type
32
+ }, ___EmotionJSX("iframe", {
33
+ title: visualElement.title,
34
+ src: visualElement.url
35
+ }));
36
+ };
37
+
38
+ export default NotionVisualElement;
@@ -1 +1,2 @@
1
- export { default as Notion } from './Notion';
1
+ export { default as Notion } from './Notion';
2
+ export { default as ConceptNotion } from './ConceptNotion';
@@ -1,5 +1,7 @@
1
1
  import _styled from "@emotion/styled-base";
2
2
 
3
+ 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)."; }
4
+
3
5
  /**
4
6
  * Copyright (c) 2020-present, NDLA.
5
7
  *
@@ -16,13 +18,26 @@ import { jsx as ___EmotionJSX } from "@emotion/core";
16
18
  export var StyledActiveFilterTitle = _styled("span", {
17
19
  target: "e90waln0",
18
20
  label: "StyledActiveFilterTitle"
19
- })("white-space:nowrap;padding-right:", spacing.small, ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFjdGl2ZUZpbHRlckNvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVrRCIsImZpbGUiOiJBY3RpdmVGaWx0ZXJDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIwLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBXaXRoVHJhbnNsYXRpb24sIHdpdGhUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQWN0aXZlRmlsdGVyVGl0bGUgPSBzdHlsZWQuc3BhbmBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmV4cG9ydCB0eXBlIEZpbHRlclByb3BzID0ge1xuICB2YWx1ZTogc3RyaW5nO1xuICB0aXRsZTogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG59O1xuXG50eXBlIFByb3BzID0ge1xuICBmaWx0ZXI6IEZpbHRlclByb3BzO1xuICBvbkZpbHRlclJlbW92ZTogKHZhbHVlOiBzdHJpbmcsIG5hbWU6IHN0cmluZykgPT4gdm9pZDtcbn07XG5cbmNvbnN0IEFjdGl2ZUZpbHRlckNvbnRlbnQgPSAoeyBmaWx0ZXIsIG9uRmlsdGVyUmVtb3ZlLCB0IH06IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSA9PiAoXG4gIDxCdXR0b25cbiAgICBhcmlhLWxhYmVsPXt0KCdzZWFyY2hQYWdlLnNlYXJjaEZpbHRlck1lc3NhZ2VzLnJlbW92ZUZpbHRlcicsIHtcbiAgICAgIGZpbHRlck5hbWU6IGZpbHRlci50aXRsZSxcbiAgICB9KX1cbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBzaXplPVwibm9ybWFsXCJcbiAgICBib3JkZXJTaGFwZT1cInJvdW5kZWRcIlxuICAgIG9uQ2xpY2s9eygpID0+IG9uRmlsdGVyUmVtb3ZlKGZpbHRlci52YWx1ZSwgZmlsdGVyLm5hbWUpfT5cbiAgICA8U3R5bGVkQWN0aXZlRmlsdGVyVGl0bGU+e2ZpbHRlci50aXRsZX08L1N0eWxlZEFjdGl2ZUZpbHRlclRpdGxlPlxuICAgIDxDcm9zcyAvPlxuICA8L0J1dHRvbj5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFjdGl2ZUZpbHRlckNvbnRlbnQpO1xuIl19 */"));
21
+ })("white-space:nowrap;padding-right:", spacing.small, ";font-weight:", fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFjdGl2ZUZpbHRlckNvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVrRCIsImZpbGUiOiJBY3RpdmVGaWx0ZXJDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIwLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCB7IHNwYWNpbmcsIGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJ0BuZGxhL2J1dHRvbic7XG5pbXBvcnQgeyBXaXRoVHJhbnNsYXRpb24sIHdpdGhUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQWN0aXZlRmlsdGVyVGl0bGUgPSBzdHlsZWQuc3BhbmBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbmA7XG5cbmNvbnN0IFN0eWxlZEJ1dHRvbiA9IHN0eWxlZChCdXR0b24pYFxuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDFmciBhdXRvO1xuYDtcblxuZXhwb3J0IHR5cGUgRmlsdGVyUHJvcHMgPSB7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbn07XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGZpbHRlcjogRmlsdGVyUHJvcHM7XG4gIG9uRmlsdGVyUmVtb3ZlOiAodmFsdWU6IHN0cmluZywgbmFtZTogc3RyaW5nKSA9PiB2b2lkO1xufTtcblxuY29uc3QgQWN0aXZlRmlsdGVyQ29udGVudCA9ICh7IGZpbHRlciwgb25GaWx0ZXJSZW1vdmUsIHQgfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IChcbiAgPFN0eWxlZEJ1dHRvblxuICAgIGFyaWEtbGFiZWw9e3QoJ3NlYXJjaFBhZ2Uuc2VhcmNoRmlsdGVyTWVzc2FnZXMucmVtb3ZlRmlsdGVyJywge1xuICAgICAgZmlsdGVyTmFtZTogZmlsdGVyLnRpdGxlLFxuICAgIH0pfVxuICAgIHR5cGU9XCJidXR0b25cIlxuICAgIHNpemU9XCJub3JtYWxcIlxuICAgIGJvcmRlclNoYXBlPVwicm91bmRlZFwiXG4gICAgb25DbGljaz17KCkgPT4gb25GaWx0ZXJSZW1vdmUoZmlsdGVyLnZhbHVlLCBmaWx0ZXIubmFtZSl9PlxuICAgIDxTdHlsZWRBY3RpdmVGaWx0ZXJUaXRsZT57ZmlsdGVyLnRpdGxlfTwvU3R5bGVkQWN0aXZlRmlsdGVyVGl0bGU+XG4gICAgPENyb3NzIC8+XG4gIDwvU3R5bGVkQnV0dG9uPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoQWN0aXZlRmlsdGVyQ29udGVudCk7XG4iXX0= */"));
22
+
23
+ var StyledButton = /*#__PURE__*/_styled(Button, {
24
+ target: "e90waln1",
25
+ label: "StyledButton"
26
+ })(process.env.NODE_ENV === "production" ? {
27
+ name: "gvap3q",
28
+ styles: "display:grid;grid-template-columns:1fr auto;"
29
+ } : {
30
+ name: "gvap3q",
31
+ styles: "display:grid;grid-template-columns:1fr auto;",
32
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFjdGl2ZUZpbHRlckNvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCbUMiLCJmaWxlIjoiQWN0aXZlRmlsdGVyQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBDcm9zcyB9IGZyb20gJ0BuZGxhL2ljb25zL2FjdGlvbic7XG5pbXBvcnQgeyBzcGFjaW5nLCBmb250cyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEJ1dHRvbiBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgV2l0aFRyYW5zbGF0aW9uLCB3aXRoVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEFjdGl2ZUZpbHRlclRpdGxlID0gc3R5bGVkLnNwYW5gXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIHBhZGRpbmctcmlnaHQ6ICR7c3BhY2luZy5zbWFsbH07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG5gO1xuXG5jb25zdCBTdHlsZWRCdXR0b24gPSBzdHlsZWQoQnV0dG9uKWBcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgYXV0bztcbmA7XG5cbmV4cG9ydCB0eXBlIEZpbHRlclByb3BzID0ge1xuICB2YWx1ZTogc3RyaW5nO1xuICB0aXRsZTogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG59O1xuXG50eXBlIFByb3BzID0ge1xuICBmaWx0ZXI6IEZpbHRlclByb3BzO1xuICBvbkZpbHRlclJlbW92ZTogKHZhbHVlOiBzdHJpbmcsIG5hbWU6IHN0cmluZykgPT4gdm9pZDtcbn07XG5cbmNvbnN0IEFjdGl2ZUZpbHRlckNvbnRlbnQgPSAoeyBmaWx0ZXIsIG9uRmlsdGVyUmVtb3ZlLCB0IH06IFByb3BzICYgV2l0aFRyYW5zbGF0aW9uKSA9PiAoXG4gIDxTdHlsZWRCdXR0b25cbiAgICBhcmlhLWxhYmVsPXt0KCdzZWFyY2hQYWdlLnNlYXJjaEZpbHRlck1lc3NhZ2VzLnJlbW92ZUZpbHRlcicsIHtcbiAgICAgIGZpbHRlck5hbWU6IGZpbHRlci50aXRsZSxcbiAgICB9KX1cbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBzaXplPVwibm9ybWFsXCJcbiAgICBib3JkZXJTaGFwZT1cInJvdW5kZWRcIlxuICAgIG9uQ2xpY2s9eygpID0+IG9uRmlsdGVyUmVtb3ZlKGZpbHRlci52YWx1ZSwgZmlsdGVyLm5hbWUpfT5cbiAgICA8U3R5bGVkQWN0aXZlRmlsdGVyVGl0bGU+e2ZpbHRlci50aXRsZX08L1N0eWxlZEFjdGl2ZUZpbHRlclRpdGxlPlxuICAgIDxDcm9zcyAvPlxuICA8L1N0eWxlZEJ1dHRvbj5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhUcmFuc2xhdGlvbigpKEFjdGl2ZUZpbHRlckNvbnRlbnQpO1xuIl19 */",
33
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
+ });
20
35
 
21
36
  var ActiveFilterContent = function ActiveFilterContent(_ref) {
22
37
  var filter = _ref.filter,
23
38
  onFilterRemove = _ref.onFilterRemove,
24
39
  t = _ref.t;
25
- return ___EmotionJSX(Button, {
40
+ return ___EmotionJSX(StyledButton, {
26
41
  "aria-label": t('searchPage.searchFilterMessages.removeFilter', {
27
42
  filterName: filter.title
28
43
  }),