@ndla/ui 23.0.0 → 24.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 (95) hide show
  1. package/es/Article/ArticleAuthorContent.js +2 -4
  2. package/es/AuthorInfo/AuthorInfo.js +29 -16
  3. package/es/ContentCard/ContentCard.js +66 -25
  4. package/es/FileList/File.js +34 -8
  5. package/es/FileList/FileList.js +29 -3
  6. package/es/InfoBox/InfoBox.js +10 -3
  7. package/es/InfoWidget/InfoWidget.js +67 -22
  8. package/es/Portrait/Portrait.js +19 -13
  9. package/es/Search/ActiveFilterContent.js +4 -14
  10. package/es/Search/ActiveFilters.js +8 -19
  11. package/es/Search/SearchField.js +31 -52
  12. package/es/Search/SearchResult.js +113 -136
  13. package/es/Search/ToggleSearchButton.js +34 -43
  14. package/es/Search/index.js +2 -8
  15. package/es/all.css +1 -1
  16. package/es/index-javascript.js +0 -1
  17. package/es/index.js +2 -1
  18. package/lib/Article/ArticleAuthorContent.js +9 -4
  19. package/lib/AuthorInfo/AuthorInfo.d.ts +1 -11
  20. package/lib/AuthorInfo/AuthorInfo.js +36 -20
  21. package/lib/ContentCard/ContentCard.d.ts +1 -15
  22. package/lib/ContentCard/ContentCard.js +60 -28
  23. package/lib/FileList/File.js +36 -12
  24. package/lib/FileList/FileList.js +28 -5
  25. package/lib/InfoBox/InfoBox.js +11 -4
  26. package/lib/InfoWidget/InfoWidget.js +61 -25
  27. package/lib/Portrait/Portrait.js +19 -14
  28. package/lib/Search/ActiveFilterContent.d.ts +13 -0
  29. package/lib/Search/ActiveFilterContent.js +4 -15
  30. package/lib/Search/ActiveFilters.d.ts +13 -0
  31. package/lib/Search/ActiveFilters.js +8 -20
  32. package/lib/Search/SearchField.d.ts +19 -0
  33. package/lib/Search/SearchField.js +32 -56
  34. package/lib/Search/SearchResult.d.ts +36 -0
  35. package/lib/Search/SearchResult.js +116 -159
  36. package/lib/Search/ToggleSearchButton.d.ts +16 -0
  37. package/lib/Search/ToggleSearchButton.js +36 -46
  38. package/lib/Search/index.d.ts +12 -0
  39. package/lib/Search/index.js +0 -54
  40. package/lib/SearchTypeResult/SearchTypeHeader.d.ts +1 -1
  41. package/lib/all.css +1 -1
  42. package/lib/index-javascript.js +0 -74
  43. package/lib/index.d.ts +1 -0
  44. package/lib/index.js +38 -1
  45. package/package.json +5 -5
  46. package/src/Article/ArticleAuthorContent.tsx +1 -1
  47. package/src/AuthorInfo/AuthorInfo.tsx +53 -19
  48. package/src/ContentCard/ContentCard.tsx +127 -35
  49. package/src/FileList/File.tsx +47 -17
  50. package/src/FileList/FileList.tsx +37 -8
  51. package/src/InfoBox/InfoBox.tsx +24 -4
  52. package/src/InfoWidget/InfoWidget.tsx +83 -34
  53. package/src/Portrait/Portrait.tsx +25 -10
  54. package/src/Search/{ActiveFilterContent.jsx → ActiveFilterContent.tsx} +11 -12
  55. package/src/Search/{ActiveFilters.jsx → ActiveFilters.tsx} +20 -17
  56. package/src/Search/{SearchField.jsx → SearchField.tsx} +58 -68
  57. package/src/Search/SearchResult.tsx +360 -0
  58. package/src/Search/ToggleSearchButton.tsx +73 -0
  59. package/src/Search/component.search.scss +0 -4
  60. package/src/Search/index.ts +16 -0
  61. package/src/all.scss +0 -1
  62. package/src/index-javascript.js +0 -15
  63. package/src/index.ts +2 -0
  64. package/src/main.scss +0 -6
  65. package/es/Search/SearchFilter.js +0 -72
  66. package/es/Search/SearchFilterList.js +0 -115
  67. package/es/Search/SearchOverlay.js +0 -39
  68. package/es/Search/SearchPage.js +0 -178
  69. package/es/Search/SearchPopoverFilter.js +0 -152
  70. package/es/Search/SearchResultAuthor.js +0 -51
  71. package/lib/Search/SearchFilter.js +0 -88
  72. package/lib/Search/SearchFilterList.js +0 -137
  73. package/lib/Search/SearchOverlay.js +0 -62
  74. package/lib/Search/SearchPage.js +0 -207
  75. package/lib/Search/SearchPopoverFilter.js +0 -172
  76. package/lib/Search/SearchResultAuthor.js +0 -60
  77. package/src/AuthorInfo/component.author-info.scss +0 -54
  78. package/src/ContentCard/component.content-card.scss +0 -109
  79. package/src/FileList/component.file-list.scss +0 -102
  80. package/src/InfoBox/component.info-box.scss +0 -21
  81. package/src/InfoWidget/component.info-widget.scss +0 -52
  82. package/src/Portrait/component.portrait.scss +0 -29
  83. package/src/Search/SearchFilter.jsx +0 -82
  84. package/src/Search/SearchFilterList.jsx +0 -110
  85. package/src/Search/SearchOverlay.jsx +0 -38
  86. package/src/Search/SearchPage.jsx +0 -178
  87. package/src/Search/SearchPopoverFilter.jsx +0 -109
  88. package/src/Search/SearchResult.jsx +0 -239
  89. package/src/Search/SearchResultAuthor.jsx +0 -54
  90. package/src/Search/ToggleSearchButton.jsx +0 -64
  91. package/src/Search/component.search-filter.scss +0 -67
  92. package/src/Search/component.search-overlay.scss +0 -103
  93. package/src/Search/component.search-page.scss +0 -125
  94. package/src/Search/component.search-result-author.scss +0 -65
  95. package/src/Search/index.js +0 -34
@@ -3,220 +3,177 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.SearchResultList = exports.SearchResultItem = exports.SearchResult = void 0;
6
+ exports.SearchResultList = exports.SearchResultItem = void 0;
7
7
 
8
- var _react = _interopRequireWildcard(require("react"));
9
-
10
- var _propTypes = _interopRequireDefault(require("prop-types"));
8
+ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
11
9
 
12
- var _reactBemHelper = _interopRequireDefault(require("react-bem-helper"));
10
+ var _react = _interopRequireWildcard(require("react"));
13
11
 
14
12
  var _common = require("@ndla/icons/common");
15
13
 
16
- var _action = require("@ndla/icons/action");
17
-
18
14
  var _util = require("@ndla/util");
19
15
 
20
16
  var _reactI18next = require("react-i18next");
21
17
 
22
- var _button = _interopRequireDefault(require("@ndla/button"));
23
-
24
- var _tabs = require("@ndla/tabs");
25
-
26
18
  var _tooltip = _interopRequireDefault(require("@ndla/tooltip"));
27
19
 
28
20
  var _safelink = _interopRequireDefault(require("@ndla/safelink"));
29
21
 
30
22
  var _icons = require("@ndla/icons");
31
23
 
32
- var _core = require("@emotion/core");
24
+ var _core = require("@ndla/core");
33
25
 
34
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
26
+ var _core2 = require("@emotion/core");
35
27
 
36
28
  function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
37
29
 
38
30
  function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
39
31
 
40
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
41
-
42
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
43
-
44
- var resultClasses = (0, _reactBemHelper["default"])('c-search-result');
45
-
46
- var SearchResult = function SearchResult(_ref) {
47
- var tabOptions = _ref.tabOptions,
48
- children = _ref.children,
49
- messages = _ref.messages,
50
- searchString = _ref.searchString,
51
- currentTab = _ref.currentTab,
52
- onTabChange = _ref.onTabChange,
53
- author = _ref.author,
54
- currentCompetenceGoal = _ref.currentCompetenceGoal,
55
- competenceGoalsOpen = _ref.competenceGoalsOpen,
56
- onToggleCompetenceGoals = _ref.onToggleCompetenceGoals,
57
- competenceGoals = _ref.competenceGoals,
58
- hideResultText = _ref.hideResultText;
59
-
60
- var _useTranslation = (0, _reactI18next.useTranslation)(),
61
- t = _useTranslation.t;
62
-
63
- return (0, _core.jsx)(_react.Fragment, null, (0, _core.jsx)("h2", resultClasses('result-label'), !hideResultText ? messages.resultHeading : "\xA0"), (0, _core.jsx)("div", resultClasses(), author || (0, _core.jsx)("div", resultClasses('heading-wrapper'), (0, _core.jsx)("h1", resultClasses('heading', currentCompetenceGoal ? 'competence-goal' : null), messages.searchStringLabel, " ", (0, _core.jsx)("span", null, searchString)), competenceGoalsOpen && (0, _core.jsx)(_button["default"], _extends({
64
- link: true
65
- }, resultClasses('close-competencegoals-btn'), {
66
- onClick: onToggleCompetenceGoals
67
- }), t('competenceGoals.closeCompetenceGoals'), (0, _core.jsx)(_action.Cross, {
68
- className: "c-icon--22 u-margin-left-tiny"
69
- }))), (0, _core.jsx)("h2", null, messages.subHeading), !competenceGoalsOpen && currentCompetenceGoal && (0, _core.jsx)("ul", resultClasses('current-goal'), (0, _core.jsx)("li", null, currentCompetenceGoal)), !competenceGoalsOpen && competenceGoals && (0, _core.jsx)("p", resultClasses('current-goal-info'), messages.openCompetenceGoalsButtonPrefix, ' ', (0, _core.jsx)(_button["default"], {
70
- link: true,
71
- onClick: onToggleCompetenceGoals
72
- }, messages.openCompetenceGoalsButton)), competenceGoalsOpen && (0, _core.jsx)("div", resultClasses('competence-goals'), competenceGoals), !competenceGoalsOpen && (0, _core.jsx)(_react.Fragment, null, (0, _core.jsx)(_tabs.FilterTabs, {
73
- dropdownBtnLabel: t('searchPage.searchPageMessages.dropdownBtnLabel'),
74
- value: currentTab,
75
- options: tabOptions,
76
- contentId: "search-result-content",
77
- onChange: onTabChange
78
- }, children), (0, _core.jsx)("div", resultClasses('narrow-result'), children))));
79
- };
80
-
81
- exports.SearchResult = SearchResult;
82
- SearchResult.propTypes = {
83
- hideResultText: _propTypes["default"].bool,
84
- tabOptions: _propTypes["default"].arrayOf(_propTypes["default"].shape({
85
- title: _propTypes["default"].string.isRequired,
86
- value: _propTypes["default"].string.isRequired
87
- })).isRequired,
88
- currentTab: _propTypes["default"].string,
89
- children: _propTypes["default"].node.isRequired,
90
- messages: _propTypes["default"].shape({
91
- searchStringLabel: _propTypes["default"].string.isRequired,
92
- subHeading: _propTypes["default"].string.isRequired,
93
- openCompetenceGoalsButtonPrefix: _propTypes["default"].string,
94
- openCompetenceGoalsButton: _propTypes["default"].string
95
- }).isRequired,
96
- currentCompetenceGoal: _propTypes["default"].string,
97
- competenceGoalsOpen: _propTypes["default"].bool,
98
- onToggleCompetenceGoals: _propTypes["default"].func,
99
- competenceGoals: _propTypes["default"].node,
100
- searchString: function searchString(props, propName, componentName) {
101
- if (props.author === null && typeof props[propName] !== 'string') {
102
- return new Error("Invalid prop 'searchString' in ".concat(componentName, ". Required unless props.author === PropTypes.node"));
103
- }
104
-
105
- return null;
106
- },
107
- onTabChange: _propTypes["default"].func.isRequired,
108
- author: _propTypes["default"].node
109
- };
110
- SearchResult.defaultProps = {
111
- author: null
112
- };
113
- var searchResultItemClasses = (0, _reactBemHelper["default"])('c-search-result-item');
114
-
115
- var searchResultItemShape = _propTypes["default"].shape({
116
- id: _propTypes["default"].oneOfType([_propTypes["default"].number, _propTypes["default"].string]).isRequired,
117
- title: _propTypes["default"].string.isRequired,
118
- url: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]).isRequired,
119
- breadcrumb: _propTypes["default"].arrayOf(_propTypes["default"].string),
120
- subjects: _propTypes["default"].arrayOf(_propTypes["default"].shape({
121
- title: _propTypes["default"].string.isRequired,
122
- url: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]).isRequired
123
- })),
124
- additional: _propTypes["default"].bool,
125
- image: _propTypes["default"].node,
126
- ingress: _propTypes["default"].string.isRequired,
127
- contentTypeIcon: _propTypes["default"].node.isRequired,
128
- contentTypeLabel: _propTypes["default"].string.isRequired
129
- });
130
-
131
- var SearchResultItem = function SearchResultItem(_ref2) {
132
- var item = _ref2.item,
133
- subjectsLabel = _ref2.subjectsLabel,
134
- additionalContentToolip = _ref2.additionalContentToolip,
135
- children = _ref2.children;
32
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
136
33
 
137
- var itemBreadcrumb = function itemBreadcrumb(item) {
138
- var _item$breadcrumb;
34
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
139
35
 
140
- var cssClasses = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
36
+ var StyledHeader = (0, _styledBase["default"])("header", {
37
+ target: "eoz7rc80",
38
+ label: "StyledHeader"
39
+ })("display:flex;flex-wrap:wrap;align-items:center;> *{margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;}", _core.mq.range({
40
+ until: _core.breakpoints.tablet
41
+ }), "{h1{width:100%;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAoCkC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
42
+ var ContentTypeWrapper = (0, _styledBase["default"])("div", {
43
+ target: "eoz7rc81",
44
+ label: "ContentTypeWrapper"
45
+ })("margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAoDqC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
46
+ var PillsWrapper = (0, _styledBase["default"])("div", {
47
+ target: "eoz7rc82",
48
+ label: "PillsWrapper"
49
+ })("background:", _core.colors.brand.greyLightest, ";margin-right:", _core.spacing.small, ";padding:0 ", _core.spacingUnit / 3, "px;border-radius:50%;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA0D+B","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
50
+ var StyledContent = (0, _styledBase["default"])("div", {
51
+ target: "eoz7rc83",
52
+ label: "StyledContent"
53
+ })("display:flex;align-items:flex-start;justify-content:space-between;& > img,& > picture > img{width:75px;height:auto;flex-shrink:0;margin:0 0 ", _core.spacing.small, " ", _core.spacing.small, ";", _core.mq.range({
54
+ from: _core.breakpoints.tabletWide
55
+ }), "{width:80px;margin-left:", _core.spacing.normal, ";margin-right:", _core.spacing.small, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAmEgC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
56
+ var StyledIngress = (0, _styledBase["default"])("p", {
57
+ target: "eoz7rc84",
58
+ label: "StyledIngress"
59
+ })("margin:0 0 ", _core.spacing.normal, " 0;width:100%;flex-grow:1;", _core.fonts.sizes('14px', '22px'), ";", _core.mq.range({
60
+ from: _core.breakpoints.tablet
61
+ }), "{", _core.fonts.sizes('16px', '24px'), ";max-width:550px;}", _core.mq.range({
62
+ from: _core.breakpoints.desktop
63
+ }), "{", _core.fonts.sizes('18px', '26px'), ";max-width:600px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAsF8B","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
64
+ var StyledSubjects = (0, _styledBase["default"])("div", {
65
+ target: "eoz7rc85",
66
+ label: "StyledSubjects"
67
+ })("display:flex;align-items:center;flex-wrap:wrap;margin-bottom:", _core.spacing.normal, ";", _core.fonts.sizes('14px', '16px'), ";", _core.mq.range({
68
+ from: _core.breakpoints.desktop
69
+ }), "{", _core.fonts.sizes('16px', '18px'), ";}& > span{text-transform:uppercase;color:", _core.colors.text.light, ";padding-right:", _core.spacing.small, ";", _core.fonts.sizes('14px', '16px'), ";}ul{display:flex;align-items:center;flex-wrap:wrap;list-style:none;margin:0;padding:0;}li{margin:0;position:relative;line-height:1rem;padding:0 ", _core.spacing.xsmall, " 0 0;margin-right:", _core.spacing.xsmall, ";", _core.mq.range({
70
+ from: _core.breakpoints.desktop
71
+ }), "{padding:0 ", _core.spacing.small, " 0 0;margin-right:", _core.spacing.small, ";}&::after{content:'';width:1px;height:15px;background:", _core.colors.brand.greyLight, ";display:block;position:absolute;right:0;top:3px;}&:first-child{font-weight:600;}&:last-child{&:after{display:none;}margin-right:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAuGiC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
72
+ var StyledSearchResultItem = (0, _styledBase["default"])("li", {
73
+ target: "eoz7rc86",
74
+ label: "StyledSearchResultItem"
75
+ })("border-bottom:1px solid ", _core.colors.brand.greyLight, ";padding:0 ", _core.spacing.normal, " 0 ", _core.spacing.normal, ";", _core.mq.range({
76
+ from: _core.breakpoints.desktop
77
+ }), "{padding:0;}margin:0 0 ", _core.spacing.normal, ";&:first-child{margin-top:", _core.spacing.normal, ";}&:last-child{border-bottom:0;margin-bottom:0;}h1{font-weight:600;", _core.fonts.sizes('16px', '20px'), ";", _core.mq.range({
78
+ from: _core.breakpoints.desktop
79
+ }), "{", _core.fonts.sizes('22px', '28px'), ";}a{color:", _core.colors.brand.dark, ";&:hover,&:focus,&:active{color:", _core.colors.brand.dark, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAuKwC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
80
+ var StyledBreadcrumb = (0, _styledBase["default"])("div", {
81
+ target: "eoz7rc87",
82
+ label: "StyledBreadcrumb"
83
+ })("list-style:none;display:flex;align-items:center;flex-wrap:wrap;color:", _core.colors.text.light, ";margin-bottom:", _core.spacing.normal, ";", _core.fonts.sizes('14px', '18px'), ";", _core.mq.range({
84
+ from: _core.breakpoints.desktop
85
+ }), "{", _core.fonts.sizes('16px', '24px'), ";}.c-icon{width:12px;height:12px;margin:0 ", _core.spacingUnit / 3, "px;", _core.mq.range({
86
+ from: _core.breakpoints.desktop
87
+ }), "{margin:0 ", _core.spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA8MmC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
88
+
89
+ var SearchResultItem = function SearchResultItem(_ref) {
90
+ var _item$url;
91
+
92
+ var item = _ref.item,
93
+ subjectsLabel = _ref.subjectsLabel,
94
+ additionalContentTooltip = _ref.additionalContentTooltip,
95
+ children = _ref.children;
96
+
97
+ var itemBreadcrumb = function itemBreadcrumb() {
98
+ var breadcrumbs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
99
+ var itemBreadcrumb = arguments.length > 1 ? arguments[1] : undefined;
100
+ var Breadcrumb = itemBreadcrumb ? StyledBreadcrumb : 'div';
101
+
102
+ if (breadcrumbs.length > 0) {
103
+ return (0, _core2.jsx)(Breadcrumb, null, breadcrumbs.map(function (breadcrumbItem, index) {
104
+ var _item$breadcrumb;
141
105
 
142
- if (((_item$breadcrumb = item.breadcrumb) === null || _item$breadcrumb === void 0 ? void 0 : _item$breadcrumb.length) > 0) {
143
- return (0, _core.jsx)("div", cssClasses, item.breadcrumb.map(function (breadcrumbItem, index) {
144
106
  var icon = null;
145
107
 
146
- if (index !== item.breadcrumb.length - 1) {
147
- icon = (0, _core.jsx)(_common.ChevronRight, null);
108
+ if (index !== (((_item$breadcrumb = item.breadcrumb) === null || _item$breadcrumb === void 0 ? void 0 : _item$breadcrumb.length) || 0) - 1) {
109
+ icon = (0, _core2.jsx)(_common.ChevronRight, null);
148
110
  }
149
111
 
150
- return (0, _core.jsx)(_react.Fragment, {
112
+ return (0, _core2.jsx)(_react.Fragment, {
151
113
  key: (0, _util.uuid)()
152
- }, (0, _core.jsx)("span", null, breadcrumbItem), icon);
114
+ }, (0, _core2.jsx)("span", null, breadcrumbItem), icon);
153
115
  }));
154
116
  }
155
117
  };
156
118
 
157
- return (0, _core.jsx)("li", _extends({
119
+ return (0, _core2.jsx)(StyledSearchResultItem, {
158
120
  key: item.id
159
- }, searchResultItemClasses()), (0, _core.jsx)("article", null, (0, _core.jsx)("header", searchResultItemClasses('header'), (0, _core.jsx)("h1", null, item.url.href ? (0, _core.jsx)("a", item.url, item.title) : (0, _core.jsx)(_safelink["default"], {
160
- to: item.url
161
- }, item.title)), (0, _core.jsx)("div", searchResultItemClasses('content-type-wrapper'), item.contentTypeIcon), item.contentTypeLabel && (0, _core.jsx)("div", searchResultItemClasses('pills'), item.contentTypeLabel), item.type && (0, _core.jsx)("div", searchResultItemClasses('pills'), item.type), item.additional && (0, _core.jsx)("div", searchResultItemClasses('pills'), additionalContentToolip), children), (0, _core.jsx)("div", searchResultItemClasses('content'), (0, _core.jsx)("p", _extends({}, searchResultItemClasses('ingress'), {
121
+ }, (0, _core2.jsx)("article", null, (0, _core2.jsx)(StyledHeader, null, (0, _core2.jsx)("h1", null, item.url && typeof item.url !== 'string' ? (0, _core2.jsx)("a", item.url, item.title) : (0, _core2.jsx)(_safelink["default"], {
122
+ to: (_item$url = item.url) !== null && _item$url !== void 0 ? _item$url : ''
123
+ }, item.title)), (0, _core2.jsx)(ContentTypeWrapper, null, item.contentTypeIcon), item.contentTypeLabel && (0, _core2.jsx)(PillsWrapper, null, item.contentTypeLabel), item.type && (0, _core2.jsx)(PillsWrapper, null, item.type), item.additional && (0, _core2.jsx)(PillsWrapper, null, additionalContentTooltip), children), (0, _core2.jsx)(StyledContent, null, (0, _core2.jsx)(StyledIngress, {
162
124
  dangerouslySetInnerHTML: {
163
125
  __html: item.ingress
164
126
  }
165
- })), item.image), (!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item, searchResultItemClasses('breadcrumb')), item.subjects && item.subjects.length !== 0 && (0, _core.jsx)("div", searchResultItemClasses('subjects'), (0, _core.jsx)("span", null, subjectsLabel), (0, _core.jsx)("ul", null, item.subjects.map(function (subject) {
166
- return (0, _core.jsx)("li", {
127
+ }), item.image), (!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true), item.subjects && item.subjects.length !== 0 && (0, _core2.jsx)(StyledSubjects, null, (0, _core2.jsx)("span", null, subjectsLabel), (0, _core2.jsx)("ul", null, item.subjects.map(function (subject) {
128
+ var _subject$url;
129
+
130
+ return (0, _core2.jsx)("li", {
167
131
  key: (0, _util.uuid)()
168
- }, (0, _core.jsx)(_tooltip["default"], {
169
- tooltip: itemBreadcrumb(subject)
170
- }, subject.url.href ? (0, _core.jsx)("a", subject.url, subject.title) : (0, _core.jsx)(_safelink["default"], {
171
- to: subject.url
132
+ }, (0, _core2.jsx)(_tooltip["default"], {
133
+ tooltip: itemBreadcrumb(subject.breadcrumb)
134
+ }, subject.url && typeof subject.url !== 'string' ? (0, _core2.jsx)("a", subject.url, subject.title) : (0, _core2.jsx)(_safelink["default"], {
135
+ to: (_subject$url = subject.url) !== null && _subject$url !== void 0 ? _subject$url : ''
172
136
  }, subject.title)));
173
137
  })))));
174
138
  };
175
139
 
176
140
  exports.SearchResultItem = SearchResultItem;
177
- SearchResultItem.propTypes = {
178
- item: searchResultItemShape.isRequired,
179
- additionalContentToolip: _propTypes["default"].string.isRequired,
180
- subjectsLabel: _propTypes["default"].string.isRequired
181
- };
182
-
183
- var SearchResultList = function SearchResultList(_ref3) {
184
- var results = _ref3.results,
185
- Component = _ref3.component,
186
- loading = _ref3.loading;
141
+ var EmptyResultList = (0, _styledBase["default"])("article", {
142
+ target: "eoz7rc88",
143
+ label: "EmptyResultList"
144
+ })("margin-top:", _core.spacing.large, ";h1{", _core.fonts.sizes('22px', '32px'), ";font-weight:", _core.fonts.weight.bold, ";margin:0 0 ", _core.spacing.small, ";}p{", _core.fonts.sizes('16px', '22px'), ";margin:0;font-family:", _core.fonts.serif, ";", _core.mq.range({
145
+ from: _core.breakpoints.desktop
146
+ }), "{", _core.fonts.sizes('18px', '32px'), ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAiTsC","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
147
+ var ResultList = (0, _styledBase["default"])("ul", {
148
+ target: "eoz7rc89",
149
+ label: "ResultList"
150
+ })("list-style:none;margin:0;padding:0;", _core.mq.range({
151
+ from: _core.breakpoints.desktop
152
+ }), "{margin:", _core.spacing.medium, " 0 0 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAoU4B","file":"SearchResult.tsx","sourcesContent":["import React, { ElementType, Fragment, ReactNode } from 'react';\nimport { ChevronRight } from '@ndla/icons/common';\nimport { uuid } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport Tooltip from '@ndla/tooltip';\nimport SafeLink from '@ndla/safelink';\nimport { Spinner } from '@ndla/icons';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\n\ninterface ItemType {\n  id: string | number;\n  title?: string;\n  url?: string | { href: string };\n  breadcrumb?: string[];\n  subjects?: {\n    title: string;\n    url?: string | { href: string };\n    breadcrumb?: string[];\n  }[];\n  additional?: boolean;\n  image?: ReactNode;\n  ingress: string;\n  contentTypeIcon?: string;\n  contentTypeLabel?: string;\n  children?: ReactNode;\n  type?: string;\n}\n\ninterface SearchResultItemProps {\n  children?: ReactNode;\n  subjectsLabel: string;\n  additionalContentTooltip: string;\n  item: ItemType;\n}\n\nconst StyledHeader = styled.header`\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n\n  > * {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    h1 {\n      width: 100%;\n    }\n  }\n`;\n\nconst ContentTypeWrapper = styled.div`\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  display: flex;\n  align-items: center;\n`;\n\nconst PillsWrapper = styled.div`\n  background: ${colors.brand.greyLightest};\n  margin-right: ${spacing.small};\n  padding: 0 ${spacingUnit / 3}px;\n  border-radius: 50%;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n`;\n\nconst StyledContent = styled.div`\n  display: flex;\n  align-items: flex-start;\n  justify-content: space-between;\n  & > img,\n  & > picture > img {\n    width: 75px;\n    height: auto;\n    flex-shrink: 0;\n    margin: 0 0 ${spacing.small} ${spacing.small};\n\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 80px;\n      margin-left: ${spacing.normal};\n      margin-right: ${spacing.small};\n    }\n  }\n`;\n\nconst StyledIngress = styled.p`\n  margin: 0 0 ${spacing.normal} 0;\n  width: 100%;\n  flex-grow: 1;\n  ${fonts.sizes('14px', '22px')};\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('16px', '24px')};\n    max-width: 550px;\n  }\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('18px', '26px')};\n    max-width: 600px;\n  }\n`;\n\nconst StyledSubjects = styled.div`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '16px')};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '18px')};\n  }\n\n  & > span {\n    text-transform: uppercase;\n    color: ${colors.text.light};\n    padding-right: ${spacing.small};\n    ${fonts.sizes('14px', '16px')};\n  }\n\n  ul {\n    display: flex;\n    align-items: center;\n    flex-wrap: wrap;\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n    position: relative;\n    line-height: 1rem;\n\n    padding: 0 ${spacing.xsmall} 0 0;\n    margin-right: ${spacing.xsmall};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      padding: 0 ${spacing.small} 0 0;\n      margin-right: ${spacing.small};\n    }\n\n    &::after {\n      content: '';\n      width: 1px;\n      height: 15px;\n      background: ${colors.brand.greyLight};\n      display: block;\n      position: absolute;\n      right: 0;\n      top: 3px;\n    }\n    &:first-child {\n      font-weight: 600;\n    }\n\n    &:last-child {\n      &:after {\n        display: none;\n      }\n\n      margin-right: 0;\n    }\n  }\n`;\n\nconst StyledSearchResultItem = styled.li`\n  border-bottom: 1px solid ${colors.brand.greyLight};\n  padding: 0 ${spacing.normal} 0 ${spacing.normal};\n\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding: 0;\n  }\n\n  margin: 0 0 ${spacing.normal};\n\n  &:first-child {\n    margin-top: ${spacing.normal};\n  }\n\n  &:last-child {\n    border-bottom: 0;\n    margin-bottom: 0;\n  }\n\n  h1 {\n    font-weight: 600;\n    ${fonts.sizes('16px', '20px')};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('22px', '28px')};\n    }\n\n    a {\n      color: ${colors.brand.dark};\n\n      &:hover,\n      &:focus,\n      &:active {\n        color: ${colors.brand.dark};\n      }\n    }\n  }\n`;\n\nconst StyledBreadcrumb = styled.div`\n  list-style: none;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  color: ${colors.text.light};\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('14px', '18px')};\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('16px', '24px')};\n  }\n  .c-icon {\n    width: 12px;\n    height: 12px;\n    margin: 0 ${spacingUnit / 3}px;\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      margin: 0 ${spacing.xsmall};\n    }\n  }\n`;\n\nexport const SearchResultItem = ({\n  item,\n  subjectsLabel,\n  additionalContentTooltip,\n  children,\n}: SearchResultItemProps) => {\n  const itemBreadcrumb = (breadcrumbs: string[] = [], itemBreadcrumb?: boolean) => {\n    const Breadcrumb: ElementType = itemBreadcrumb ? StyledBreadcrumb : 'div';\n    if (breadcrumbs.length > 0) {\n      return (\n        <Breadcrumb>\n          {breadcrumbs.map((breadcrumbItem, index) => {\n            let icon = null;\n            if (index !== (item.breadcrumb?.length || 0) - 1) {\n              icon = <ChevronRight />;\n            }\n            return (\n              <Fragment key={uuid()}>\n                <span>{breadcrumbItem}</span>\n                {icon}\n              </Fragment>\n            );\n          })}\n        </Breadcrumb>\n      );\n    }\n  };\n  return (\n    <StyledSearchResultItem key={item.id}>\n      <article>\n        <StyledHeader>\n          <h1>\n            {item.url && typeof item.url !== 'string' ? (\n              <a {...item.url}>{item.title}</a>\n            ) : (\n              <SafeLink to={item.url ?? ''}>{item.title}</SafeLink>\n            )}\n          </h1>\n          <ContentTypeWrapper>{item.contentTypeIcon}</ContentTypeWrapper>\n          {item.contentTypeLabel && <PillsWrapper>{item.contentTypeLabel}</PillsWrapper>}\n          {item.type && <PillsWrapper>{item.type}</PillsWrapper>}\n          {item.additional && <PillsWrapper>{additionalContentTooltip}</PillsWrapper>}\n          {children}\n        </StyledHeader>\n        <StyledContent>\n          <StyledIngress dangerouslySetInnerHTML={{ __html: item.ingress }} />\n          {item.image}\n        </StyledContent>\n        {(!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true)}\n        {item.subjects && item.subjects.length !== 0 && (\n          <StyledSubjects>\n            <span>{subjectsLabel}</span>\n            <ul>\n              {item.subjects.map((subject) => (\n                <li key={uuid()}>\n                  <Tooltip tooltip={itemBreadcrumb(subject.breadcrumb)}>\n                    {subject.url && typeof subject.url !== 'string' ? (\n                      <a {...subject.url}>{subject.title}</a>\n                    ) : (\n                      <SafeLink to={subject.url ?? ''}>{subject.title}</SafeLink>\n                    )}\n                  </Tooltip>\n                </li>\n              ))}\n            </ul>\n          </StyledSubjects>\n        )}\n      </article>\n    </StyledSearchResultItem>\n  );\n};\n\ninterface SearchResultListProps {\n  loading?: boolean;\n  results?: ItemType[];\n}\n\nconst EmptyResultList = styled.article`\n  margin-top: ${spacing.large};\n  h1 {\n    ${fonts.sizes('22px', '32px')};\n    font-weight: ${fonts.weight.bold};\n    margin: 0 0 ${spacing.small};\n  }\n\n  p {\n    ${fonts.sizes('16px', '22px')};\n    margin: 0;\n    font-family: ${fonts.serif};\n\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('18px', '32px')};\n    }\n  }\n`;\n\nconst ResultList = styled.ul`\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin: ${spacing.medium} 0 0 0;\n  }\n`;\n\nexport const SearchResultList = ({ results, loading }: SearchResultListProps) => {\n  const { t } = useTranslation();\n  if (loading) {\n    return <Spinner />;\n  }\n  if (!results) {\n    return <EmptyResultList />;\n  }\n  return results.length === 0 ? (\n    <EmptyResultList>\n      <h1>{t('searchPage.searchResultListMessages.noResultHeading')}</h1>\n      <p>{t('searchPage.searchResultListMessages.noResultDescription')}</p>\n    </EmptyResultList>\n  ) : (\n    <ResultList>\n      {results.map((item) => (\n        <SearchResultItem\n          key={`search_result_item_${typeof item.url === 'object' ? item.url.href : item.url}`}\n          item={item}\n          additionalContentTooltip={t('resource.tooltipAdditionalTopic')}\n          subjectsLabel={t('searchPage.searchResultListMessages.subjectsLabel')}>\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
153
+
154
+ var SearchResultList = function SearchResultList(_ref2) {
155
+ var results = _ref2.results,
156
+ loading = _ref2.loading;
187
157
 
188
- var _useTranslation2 = (0, _reactI18next.useTranslation)(),
189
- t = _useTranslation2.t;
158
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
159
+ t = _useTranslation.t;
190
160
 
191
161
  if (loading) {
192
- return (0, _core.jsx)(_icons.Spinner, null);
162
+ return (0, _core2.jsx)(_icons.Spinner, null);
193
163
  }
194
164
 
195
165
  if (!results) {
196
- return (0, _core.jsx)("article", {
197
- className: "c-search-result-list__empty"
198
- });
166
+ return (0, _core2.jsx)(EmptyResultList, null);
199
167
  }
200
168
 
201
- return results.length === 0 ? (0, _core.jsx)("article", {
202
- className: "c-search-result-list__empty"
203
- }, (0, _core.jsx)("h1", null, t('searchPage.searchResultListMessages.noResultHeading')), (0, _core.jsx)("p", null, t('searchPage.searchResultListMessages.noResultDescription'))) : (0, _core.jsx)("ul", {
204
- className: "c-search-result-list"
205
- }, results.map(function (item) {
206
- return (0, _core.jsx)(Component, {
169
+ return results.length === 0 ? (0, _core2.jsx)(EmptyResultList, null, (0, _core2.jsx)("h1", null, t('searchPage.searchResultListMessages.noResultHeading')), (0, _core2.jsx)("p", null, t('searchPage.searchResultListMessages.noResultDescription'))) : (0, _core2.jsx)(ResultList, null, results.map(function (item) {
170
+ return (0, _core2.jsx)(SearchResultItem, {
207
171
  key: "search_result_item_".concat(_typeof(item.url) === 'object' ? item.url.href : item.url),
208
172
  item: item,
209
- additionalContentToolip: t('resource.tooltipAdditionalTopic'),
173
+ additionalContentTooltip: t('resource.tooltipAdditionalTopic'),
210
174
  subjectsLabel: t('searchPage.searchResultListMessages.subjectsLabel')
211
175
  }, item.children);
212
176
  }));
213
177
  };
214
178
 
215
- exports.SearchResultList = SearchResultList;
216
- SearchResultList.defaultProps = {
217
- component: SearchResultItem
218
- };
219
- SearchResultList.propTypes = {
220
- results: _propTypes["default"].arrayOf(searchResultItemShape),
221
- loading: _propTypes["default"].bool
222
- };
179
+ exports.SearchResultList = SearchResultList;