@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
@@ -1,118 +1,97 @@
1
- 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); }
1
+ import _styled from "@emotion/styled-base";
2
2
 
3
- 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); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
4
 
5
5
  import React, { Fragment } from 'react';
6
- import PropTypes from 'prop-types';
7
- import BEMHelper from 'react-bem-helper';
8
6
  import { ChevronRight } from '@ndla/icons/common';
9
- import { Cross } from '@ndla/icons/action';
10
7
  import { uuid } from '@ndla/util';
11
8
  import { useTranslation } from 'react-i18next';
12
- import Button from '@ndla/button';
13
- import { FilterTabs } from '@ndla/tabs';
14
9
  import Tooltip from '@ndla/tooltip';
15
10
  import SafeLink from '@ndla/safelink';
16
11
  import { Spinner } from '@ndla/icons';
12
+ import { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';
17
13
  import { jsx as ___EmotionJSX } from "@emotion/core";
18
- var resultClasses = BEMHelper('c-search-result');
19
- export var SearchResult = function SearchResult(_ref) {
20
- var tabOptions = _ref.tabOptions,
21
- children = _ref.children,
22
- messages = _ref.messages,
23
- searchString = _ref.searchString,
24
- currentTab = _ref.currentTab,
25
- onTabChange = _ref.onTabChange,
26
- author = _ref.author,
27
- currentCompetenceGoal = _ref.currentCompetenceGoal,
28
- competenceGoalsOpen = _ref.competenceGoalsOpen,
29
- onToggleCompetenceGoals = _ref.onToggleCompetenceGoals,
30
- competenceGoals = _ref.competenceGoals,
31
- hideResultText = _ref.hideResultText;
32
14
 
33
- var _useTranslation = useTranslation(),
34
- t = _useTranslation.t;
15
+ var StyledHeader = _styled("header", {
16
+ target: "eoz7rc80",
17
+ label: "StyledHeader"
18
+ })("display:flex;flex-wrap:wrap;align-items:center;> *{margin:0 ", spacing.small, " ", spacing.small, " 0;}", mq.range({
19
+ until: breakpoints.tablet
20
+ }), "{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"]} */"));
35
21
 
36
- return ___EmotionJSX(Fragment, null, ___EmotionJSX("h2", resultClasses('result-label'), !hideResultText ? messages.resultHeading : "\xA0"), ___EmotionJSX("div", resultClasses(), author || ___EmotionJSX("div", resultClasses('heading-wrapper'), ___EmotionJSX("h1", resultClasses('heading', currentCompetenceGoal ? 'competence-goal' : null), messages.searchStringLabel, " ", ___EmotionJSX("span", null, searchString)), competenceGoalsOpen && ___EmotionJSX(Button, _extends({
37
- link: true
38
- }, resultClasses('close-competencegoals-btn'), {
39
- onClick: onToggleCompetenceGoals
40
- }), t('competenceGoals.closeCompetenceGoals'), ___EmotionJSX(Cross, {
41
- className: "c-icon--22 u-margin-left-tiny"
42
- }))), ___EmotionJSX("h2", null, messages.subHeading), !competenceGoalsOpen && currentCompetenceGoal && ___EmotionJSX("ul", resultClasses('current-goal'), ___EmotionJSX("li", null, currentCompetenceGoal)), !competenceGoalsOpen && competenceGoals && ___EmotionJSX("p", resultClasses('current-goal-info'), messages.openCompetenceGoalsButtonPrefix, ' ', ___EmotionJSX(Button, {
43
- link: true,
44
- onClick: onToggleCompetenceGoals
45
- }, messages.openCompetenceGoalsButton)), competenceGoalsOpen && ___EmotionJSX("div", resultClasses('competence-goals'), competenceGoals), !competenceGoalsOpen && ___EmotionJSX(Fragment, null, ___EmotionJSX(FilterTabs, {
46
- dropdownBtnLabel: t('searchPage.searchPageMessages.dropdownBtnLabel'),
47
- value: currentTab,
48
- options: tabOptions,
49
- contentId: "search-result-content",
50
- onChange: onTabChange
51
- }, children), ___EmotionJSX("div", resultClasses('narrow-result'), children))));
52
- };
53
- SearchResult.propTypes = {
54
- hideResultText: PropTypes.bool,
55
- tabOptions: PropTypes.arrayOf(PropTypes.shape({
56
- title: PropTypes.string.isRequired,
57
- value: PropTypes.string.isRequired
58
- })).isRequired,
59
- currentTab: PropTypes.string,
60
- children: PropTypes.node.isRequired,
61
- messages: PropTypes.shape({
62
- searchStringLabel: PropTypes.string.isRequired,
63
- subHeading: PropTypes.string.isRequired,
64
- openCompetenceGoalsButtonPrefix: PropTypes.string,
65
- openCompetenceGoalsButton: PropTypes.string
66
- }).isRequired,
67
- currentCompetenceGoal: PropTypes.string,
68
- competenceGoalsOpen: PropTypes.bool,
69
- onToggleCompetenceGoals: PropTypes.func,
70
- competenceGoals: PropTypes.node,
71
- searchString: function searchString(props, propName, componentName) {
72
- if (props.author === null && typeof props[propName] !== 'string') {
73
- return new Error("Invalid prop 'searchString' in ".concat(componentName, ". Required unless props.author === PropTypes.node"));
74
- }
22
+ var ContentTypeWrapper = _styled("div", {
23
+ target: "eoz7rc81",
24
+ label: "ContentTypeWrapper"
25
+ })("margin:0 ", spacing.small, " ", 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"]} */"));
26
+
27
+ var PillsWrapper = _styled("div", {
28
+ target: "eoz7rc82",
29
+ label: "PillsWrapper"
30
+ })("background:", colors.brand.greyLightest, ";margin-right:", spacing.small, ";padding:0 ", spacingUnit / 3, "px;border-radius:50%;", fonts.sizes('12px', '20px'), ";font-weight:", 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"]} */"));
31
+
32
+ var StyledContent = _styled("div", {
33
+ target: "eoz7rc83",
34
+ label: "StyledContent"
35
+ })("display:flex;align-items:flex-start;justify-content:space-between;& > img,& > picture > img{width:75px;height:auto;flex-shrink:0;margin:0 0 ", spacing.small, " ", spacing.small, ";", mq.range({
36
+ from: breakpoints.tabletWide
37
+ }), "{width:80px;margin-left:", spacing.normal, ";margin-right:", 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"]} */"));
38
+
39
+ var StyledIngress = _styled("p", {
40
+ target: "eoz7rc84",
41
+ label: "StyledIngress"
42
+ })("margin:0 0 ", spacing.normal, " 0;width:100%;flex-grow:1;", fonts.sizes('14px', '22px'), ";", mq.range({
43
+ from: breakpoints.tablet
44
+ }), "{", fonts.sizes('16px', '24px'), ";max-width:550px;}", mq.range({
45
+ from: breakpoints.desktop
46
+ }), "{", 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"]} */"));
47
+
48
+ var StyledSubjects = _styled("div", {
49
+ target: "eoz7rc85",
50
+ label: "StyledSubjects"
51
+ })("display:flex;align-items:center;flex-wrap:wrap;margin-bottom:", spacing.normal, ";", fonts.sizes('14px', '16px'), ";", mq.range({
52
+ from: breakpoints.desktop
53
+ }), "{", fonts.sizes('16px', '18px'), ";}& > span{text-transform:uppercase;color:", colors.text.light, ";padding-right:", spacing.small, ";", 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 ", spacing.xsmall, " 0 0;margin-right:", spacing.xsmall, ";", mq.range({
54
+ from: breakpoints.desktop
55
+ }), "{padding:0 ", spacing.small, " 0 0;margin-right:", spacing.small, ";}&::after{content:'';width:1px;height:15px;background:", 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"]} */"));
56
+
57
+ var StyledSearchResultItem = _styled("li", {
58
+ target: "eoz7rc86",
59
+ label: "StyledSearchResultItem"
60
+ })("border-bottom:1px solid ", colors.brand.greyLight, ";padding:0 ", spacing.normal, " 0 ", spacing.normal, ";", mq.range({
61
+ from: breakpoints.desktop
62
+ }), "{padding:0;}margin:0 0 ", spacing.normal, ";&:first-child{margin-top:", spacing.normal, ";}&:last-child{border-bottom:0;margin-bottom:0;}h1{font-weight:600;", fonts.sizes('16px', '20px'), ";", mq.range({
63
+ from: breakpoints.desktop
64
+ }), "{", fonts.sizes('22px', '28px'), ";}a{color:", colors.brand.dark, ";&:hover,&:focus,&:active{color:", 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"]} */"));
65
+
66
+ var StyledBreadcrumb = _styled("div", {
67
+ target: "eoz7rc87",
68
+ label: "StyledBreadcrumb"
69
+ })("list-style:none;display:flex;align-items:center;flex-wrap:wrap;color:", colors.text.light, ";margin-bottom:", spacing.normal, ";", fonts.sizes('14px', '18px'), ";", mq.range({
70
+ from: breakpoints.desktop
71
+ }), "{", fonts.sizes('16px', '24px'), ";}.c-icon{width:12px;height:12px;margin:0 ", spacingUnit / 3, "px;", mq.range({
72
+ from: breakpoints.desktop
73
+ }), "{margin:0 ", 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"]} */"));
74
+
75
+ export var SearchResultItem = function SearchResultItem(_ref) {
76
+ var _item$url;
77
+
78
+ var item = _ref.item,
79
+ subjectsLabel = _ref.subjectsLabel,
80
+ additionalContentTooltip = _ref.additionalContentTooltip,
81
+ children = _ref.children;
82
+
83
+ var itemBreadcrumb = function itemBreadcrumb() {
84
+ var breadcrumbs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
85
+ var itemBreadcrumb = arguments.length > 1 ? arguments[1] : undefined;
86
+ var Breadcrumb = itemBreadcrumb ? StyledBreadcrumb : 'div';
87
+
88
+ if (breadcrumbs.length > 0) {
89
+ return ___EmotionJSX(Breadcrumb, null, breadcrumbs.map(function (breadcrumbItem, index) {
90
+ var _item$breadcrumb;
75
91
 
76
- return null;
77
- },
78
- onTabChange: PropTypes.func.isRequired,
79
- author: PropTypes.node
80
- };
81
- SearchResult.defaultProps = {
82
- author: null
83
- };
84
- var searchResultItemClasses = BEMHelper('c-search-result-item');
85
- var searchResultItemShape = PropTypes.shape({
86
- id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
87
- title: PropTypes.string.isRequired,
88
- url: PropTypes.oneOfType([PropTypes.string, PropTypes.object]).isRequired,
89
- breadcrumb: PropTypes.arrayOf(PropTypes.string),
90
- subjects: PropTypes.arrayOf(PropTypes.shape({
91
- title: PropTypes.string.isRequired,
92
- url: PropTypes.oneOfType([PropTypes.string, PropTypes.object]).isRequired
93
- })),
94
- additional: PropTypes.bool,
95
- image: PropTypes.node,
96
- ingress: PropTypes.string.isRequired,
97
- contentTypeIcon: PropTypes.node.isRequired,
98
- contentTypeLabel: PropTypes.string.isRequired
99
- });
100
- export var SearchResultItem = function SearchResultItem(_ref2) {
101
- var item = _ref2.item,
102
- subjectsLabel = _ref2.subjectsLabel,
103
- additionalContentToolip = _ref2.additionalContentToolip,
104
- children = _ref2.children;
105
-
106
- var itemBreadcrumb = function itemBreadcrumb(item) {
107
- var _item$breadcrumb;
108
-
109
- var cssClasses = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
110
-
111
- if (((_item$breadcrumb = item.breadcrumb) === null || _item$breadcrumb === void 0 ? void 0 : _item$breadcrumb.length) > 0) {
112
- return ___EmotionJSX("div", cssClasses, item.breadcrumb.map(function (breadcrumbItem, index) {
113
92
  var icon = null;
114
93
 
115
- if (index !== item.breadcrumb.length - 1) {
94
+ if (index !== (((_item$breadcrumb = item.breadcrumb) === null || _item$breadcrumb === void 0 ? void 0 : _item$breadcrumb.length) || 0) - 1) {
116
95
  icon = ___EmotionJSX(ChevronRight, null);
117
96
  }
118
97
 
@@ -123,64 +102,62 @@ export var SearchResultItem = function SearchResultItem(_ref2) {
123
102
  }
124
103
  };
125
104
 
126
- return ___EmotionJSX("li", _extends({
105
+ return ___EmotionJSX(StyledSearchResultItem, {
127
106
  key: item.id
128
- }, searchResultItemClasses()), ___EmotionJSX("article", null, ___EmotionJSX("header", searchResultItemClasses('header'), ___EmotionJSX("h1", null, item.url.href ? ___EmotionJSX("a", item.url, item.title) : ___EmotionJSX(SafeLink, {
129
- to: item.url
130
- }, item.title)), ___EmotionJSX("div", searchResultItemClasses('content-type-wrapper'), item.contentTypeIcon), item.contentTypeLabel && ___EmotionJSX("div", searchResultItemClasses('pills'), item.contentTypeLabel), item.type && ___EmotionJSX("div", searchResultItemClasses('pills'), item.type), item.additional && ___EmotionJSX("div", searchResultItemClasses('pills'), additionalContentToolip), children), ___EmotionJSX("div", searchResultItemClasses('content'), ___EmotionJSX("p", _extends({}, searchResultItemClasses('ingress'), {
107
+ }, ___EmotionJSX("article", null, ___EmotionJSX(StyledHeader, null, ___EmotionJSX("h1", null, item.url && typeof item.url !== 'string' ? ___EmotionJSX("a", item.url, item.title) : ___EmotionJSX(SafeLink, {
108
+ to: (_item$url = item.url) !== null && _item$url !== void 0 ? _item$url : ''
109
+ }, item.title)), ___EmotionJSX(ContentTypeWrapper, null, item.contentTypeIcon), item.contentTypeLabel && ___EmotionJSX(PillsWrapper, null, item.contentTypeLabel), item.type && ___EmotionJSX(PillsWrapper, null, item.type), item.additional && ___EmotionJSX(PillsWrapper, null, additionalContentTooltip), children), ___EmotionJSX(StyledContent, null, ___EmotionJSX(StyledIngress, {
131
110
  dangerouslySetInnerHTML: {
132
111
  __html: item.ingress
133
112
  }
134
- })), item.image), (!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item, searchResultItemClasses('breadcrumb')), item.subjects && item.subjects.length !== 0 && ___EmotionJSX("div", searchResultItemClasses('subjects'), ___EmotionJSX("span", null, subjectsLabel), ___EmotionJSX("ul", null, item.subjects.map(function (subject) {
113
+ }), item.image), (!item.subjects || item.subjects.length === 0) && itemBreadcrumb(item.breadcrumb, true), item.subjects && item.subjects.length !== 0 && ___EmotionJSX(StyledSubjects, null, ___EmotionJSX("span", null, subjectsLabel), ___EmotionJSX("ul", null, item.subjects.map(function (subject) {
114
+ var _subject$url;
115
+
135
116
  return ___EmotionJSX("li", {
136
117
  key: uuid()
137
118
  }, ___EmotionJSX(Tooltip, {
138
- tooltip: itemBreadcrumb(subject)
139
- }, subject.url.href ? ___EmotionJSX("a", subject.url, subject.title) : ___EmotionJSX(SafeLink, {
140
- to: subject.url
119
+ tooltip: itemBreadcrumb(subject.breadcrumb)
120
+ }, subject.url && typeof subject.url !== 'string' ? ___EmotionJSX("a", subject.url, subject.title) : ___EmotionJSX(SafeLink, {
121
+ to: (_subject$url = subject.url) !== null && _subject$url !== void 0 ? _subject$url : ''
141
122
  }, subject.title)));
142
123
  })))));
143
124
  };
144
- SearchResultItem.propTypes = {
145
- item: searchResultItemShape.isRequired,
146
- additionalContentToolip: PropTypes.string.isRequired,
147
- subjectsLabel: PropTypes.string.isRequired
148
- };
149
- export var SearchResultList = function SearchResultList(_ref3) {
150
- var results = _ref3.results,
151
- Component = _ref3.component,
152
- loading = _ref3.loading;
153
125
 
154
- var _useTranslation2 = useTranslation(),
155
- t = _useTranslation2.t;
126
+ var EmptyResultList = _styled("article", {
127
+ target: "eoz7rc88",
128
+ label: "EmptyResultList"
129
+ })("margin-top:", spacing.large, ";h1{", fonts.sizes('22px', '32px'), ";font-weight:", fonts.weight.bold, ";margin:0 0 ", spacing.small, ";}p{", fonts.sizes('16px', '22px'), ";margin:0;font-family:", fonts.serif, ";", mq.range({
130
+ from: breakpoints.desktop
131
+ }), "{", 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"]} */"));
132
+
133
+ var ResultList = _styled("ul", {
134
+ target: "eoz7rc89",
135
+ label: "ResultList"
136
+ })("list-style:none;margin:0;padding:0;", mq.range({
137
+ from: breakpoints.desktop
138
+ }), "{margin:", 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"]} */"));
139
+
140
+ export var SearchResultList = function SearchResultList(_ref2) {
141
+ var results = _ref2.results,
142
+ loading = _ref2.loading;
143
+
144
+ var _useTranslation = useTranslation(),
145
+ t = _useTranslation.t;
156
146
 
157
147
  if (loading) {
158
148
  return ___EmotionJSX(Spinner, null);
159
149
  }
160
150
 
161
151
  if (!results) {
162
- return ___EmotionJSX("article", {
163
- className: "c-search-result-list__empty"
164
- });
152
+ return ___EmotionJSX(EmptyResultList, null);
165
153
  }
166
154
 
167
- return results.length === 0 ? ___EmotionJSX("article", {
168
- className: "c-search-result-list__empty"
169
- }, ___EmotionJSX("h1", null, t('searchPage.searchResultListMessages.noResultHeading')), ___EmotionJSX("p", null, t('searchPage.searchResultListMessages.noResultDescription'))) : ___EmotionJSX("ul", {
170
- className: "c-search-result-list"
171
- }, results.map(function (item) {
172
- return ___EmotionJSX(Component, {
155
+ return results.length === 0 ? ___EmotionJSX(EmptyResultList, null, ___EmotionJSX("h1", null, t('searchPage.searchResultListMessages.noResultHeading')), ___EmotionJSX("p", null, t('searchPage.searchResultListMessages.noResultDescription'))) : ___EmotionJSX(ResultList, null, results.map(function (item) {
156
+ return ___EmotionJSX(SearchResultItem, {
173
157
  key: "search_result_item_".concat(_typeof(item.url) === 'object' ? item.url.href : item.url),
174
158
  item: item,
175
- additionalContentToolip: t('resource.tooltipAdditionalTopic'),
159
+ additionalContentTooltip: t('resource.tooltipAdditionalTopic'),
176
160
  subjectsLabel: t('searchPage.searchResultListMessages.subjectsLabel')
177
161
  }, item.children);
178
162
  }));
179
- };
180
- SearchResultList.defaultProps = {
181
- component: SearchResultItem
182
- };
183
- SearchResultList.propTypes = {
184
- results: PropTypes.arrayOf(searchResultItemShape),
185
- loading: PropTypes.bool
186
163
  };