@ndla/ui 50.6.0 → 50.6.2

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.
@@ -28,21 +28,21 @@ const StyledHeader = /*#__PURE__*/(0, _base.default)("header", {
28
28
  label: "StyledHeader"
29
29
  })("display:flex;flex-wrap:wrap;align-items:center;>*{margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;}", _core.mq.range({
30
30
  until: _core.breakpoints.tablet
31
- }), "{h1{width:100%;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4CkC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
31
+ }), "{h1{width:100%;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4CkC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
32
32
  const ContentTypeWrapper = /*#__PURE__*/(0, _base.default)("div", {
33
33
  target: "eoz7rc88",
34
34
  label: "ContentTypeWrapper"
35
- })("margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4DqC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
35
+ })("margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4DqC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
36
36
  const PillsWrapper = /*#__PURE__*/(0, _base.default)("div", {
37
37
  target: "eoz7rc87",
38
38
  label: "PillsWrapper"
39
- })("background:", _core.colors.brand.greyLightest, ";margin-right:", _core.spacing.small, ";padding:0 ", _core.spacingUnit / 3, "px;border-radius:50%;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAkE+B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
39
+ })("background:", _core.colors.brand.greyLightest, ";margin-right:", _core.spacing.small, ";padding:0 ", _core.spacingUnit / 3, "px;border-radius:50%;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.fonts.weight.semibold, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAkE+B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
40
40
  const StyledContent = /*#__PURE__*/(0, _base.default)("div", {
41
41
  target: "eoz7rc86",
42
42
  label: "StyledContent"
43
43
  })("display:flex;align-items:flex-start;justify-content:space-between;&>img,&>picture>img{width:75px;height:auto;flex-shrink:0;margin:0 0 ", _core.spacing.small, " ", _core.spacing.small, ";", _core.mq.range({
44
44
  from: _core.breakpoints.tabletWide
45
- }), "{width:80px;margin-left:", _core.spacing.normal, ";margin-right:", _core.spacing.small, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA2EgC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
45
+ }), "{width:80px;margin-left:", _core.spacing.normal, ";margin-right:", _core.spacing.small, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA2EgC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
46
46
  const StyledIngress = /*#__PURE__*/(0, _base.default)("p", {
47
47
  target: "eoz7rc85",
48
48
  label: "StyledIngress"
@@ -50,7 +50,7 @@ const StyledIngress = /*#__PURE__*/(0, _base.default)("p", {
50
50
  from: _core.breakpoints.tablet
51
51
  }), "{", _core.fonts.sizes('16px', '24px'), ";max-width:550px;}", _core.mq.range({
52
52
  from: _core.breakpoints.desktop
53
- }), "{", _core.fonts.sizes('18px', '26px'), ";max-width:600px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA8F8B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
53
+ }), "{", _core.fonts.sizes('18px', '26px'), ";max-width:600px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA8F8B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
54
54
  const StyledSubjects = /*#__PURE__*/(0, _base.default)("div", {
55
55
  target: "eoz7rc84",
56
56
  label: "StyledSubjects"
@@ -58,7 +58,7 @@ const StyledSubjects = /*#__PURE__*/(0, _base.default)("div", {
58
58
  from: _core.breakpoints.desktop
59
59
  }), "{", _core.fonts.sizes('16px', '18px'), ";}&>span{text-transform:uppercase;color:", _core.colors.text.light, ";padding-right:", _core.spacing.small, ";", _core.fonts.sizes('14px', '16px'), ";}ul{display:flex;align-items:center;flex-wrap:wrap;list-style:none;margin:0;padding:0;}li{margin:0;position:relative;line-height:1rem;padding:0 ", _core.spacing.xsmall, " 0 0;margin-right:", _core.spacing.xsmall, ";", _core.mq.range({
60
60
  from: _core.breakpoints.desktop
61
- }), "{padding:0 ", _core.spacing.small, " 0 0;margin-right:", _core.spacing.small, ";}&::after{content:'';width:1px;height:15px;background:", _core.colors.brand.greyLight, ";display:block;position:absolute;right:0;top:3px;}&:first-child{font-weight:600;}&:last-child{margin-right:0;&:after{display:none;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA+GiC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
61
+ }), "{padding:0 ", _core.spacing.small, " 0 0;margin-right:", _core.spacing.small, ";}&::after{content:'';width:1px;height:15px;background:", _core.colors.brand.greyLight, ";display:block;position:absolute;right:0;top:3px;}&:first-child{font-weight:600;}&:last-child{margin-right:0;&:after{display:none;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA+GiC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
62
62
  const StyledSearchResultItem = /*#__PURE__*/(0, _base.default)("li", {
63
63
  target: "eoz7rc83",
64
64
  label: "StyledSearchResultItem"
@@ -66,15 +66,15 @@ const StyledSearchResultItem = /*#__PURE__*/(0, _base.default)("li", {
66
66
  from: _core.breakpoints.desktop
67
67
  }), "{padding:0;}margin:0 0 ", _core.spacing.normal, ";&:first-child{margin-top:", _core.spacing.normal, ";}&:last-child{border-bottom:0;margin-bottom:0;}h1{font-weight:600;", _core.fonts.sizes('16px', '20px'), ";", _core.mq.range({
68
68
  from: _core.breakpoints.desktop
69
- }), "{", _core.fonts.sizes('22px', '28px'), ";}a{color:", _core.colors.brand.dark, ";&:hover,&:focus,&:active{color:", _core.colors.brand.dark, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA+KwC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
69
+ }), "{", _core.fonts.sizes('22px', '28px'), ";}a{color:", _core.colors.brand.dark, ";&:hover,&:focus,&:active{color:", _core.colors.brand.dark, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA+KwC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
70
70
  const StyledBreadcrumb = /*#__PURE__*/(0, _base.default)("div", {
71
71
  target: "eoz7rc82",
72
72
  label: "StyledBreadcrumb"
73
73
  })("list-style:none;display:flex;align-items:center;flex-wrap:wrap;color:", _core.colors.text.light, ";margin-bottom:", _core.spacing.normal, ";", _core.fonts.sizes('14px', '18px'), ";", _core.mq.range({
74
74
  from: _core.breakpoints.desktop
75
- }), "{", _core.fonts.sizes('16px', '24px'), ";}.c-icon{width:12px;height:12px;margin:0 ", _core.spacingUnit / 3, "px;", _core.mq.range({
75
+ }), "{", _core.fonts.sizes('16px', '24px'), ";}[data-icon]{width:", _core.spacing.small, ";height:", _core.spacing.small, ";margin:0 ", _core.spacingUnit / 3, "px;", _core.mq.range({
76
76
  from: _core.breakpoints.desktop
77
- }), "{margin:0 ", _core.spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAsNmC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
77
+ }), "{margin:0 ", _core.spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAsNmC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
78
78
  const SearchResultItem = _ref => {
79
79
  let {
80
80
  item,
@@ -155,13 +155,13 @@ const EmptyResultList = /*#__PURE__*/(0, _base.default)("article", {
155
155
  label: "EmptyResultList"
156
156
  })("margin-top:", _core.spacing.large, ";h1{", _core.fonts.sizes('22px', '32px'), ";font-weight:", _core.fonts.weight.bold, ";margin:0 0 ", _core.spacing.small, ";}p{", _core.fonts.sizes('16px', '22px'), ";margin:0;font-family:", _core.fonts.serif, ";", _core.mq.range({
157
157
  from: _core.breakpoints.desktop
158
- }), "{", _core.fonts.sizes('18px', '32px'), ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAyTsC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
158
+ }), "{", _core.fonts.sizes('18px', '32px'), ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAyTsC","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
159
159
  const ResultList = /*#__PURE__*/(0, _base.default)("ul", {
160
160
  target: "eoz7rc80",
161
161
  label: "ResultList"
162
162
  })("list-style:none;margin:0;padding:0;", _core.mq.range({
163
163
  from: _core.breakpoints.desktop
164
- }), "{margin:", _core.spacing.medium, " 0 0 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4U4B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
164
+ }), "{margin:", _core.spacing.medium, " 0 0 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4U4B","file":"SearchResult.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ElementType, Fragment, ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { fonts, mq, spacing, breakpoints, colors, spacingUnit } from '@ndla/core';\nimport { Spinner } from '@ndla/icons';\nimport { ChevronRight } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport { uuid } from '@ndla/util';\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  [data-icon] {\n    width: ${spacing.small};\n    height: ${spacing.small};\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        >\n          {item.children}\n        </SearchResultItem>\n      ))}\n    </ResultList>\n  );\n};\n"]} */"));
165
165
  const SearchResultList = _ref2 => {
166
166
  let {
167
167
  results,