@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.
- package/es/CompetenceGoalTab/SearchButton.js +3 -3
- package/es/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/es/FileList/FileList.js +3 -3
- package/es/LearningPaths/LearningPathMenuIntro.js +6 -6
- package/es/LearningPaths/LearningPathSticky.js +6 -8
- package/es/Search/ContentTypeResult.js +3 -3
- package/es/Search/SearchResult.js +11 -11
- package/es/Search/SearchResultSleeve.js +11 -11
- package/es/all.css +1 -1
- package/lib/CompetenceGoalTab/SearchButton.js +3 -3
- package/lib/ErrorMessage/ErrorResourceAccessDenied.js +3 -3
- package/lib/FileList/FileList.js +3 -3
- package/lib/LearningPaths/LearningPathMenuIntro.js +6 -6
- package/lib/LearningPaths/LearningPathSticky.js +6 -8
- package/lib/Search/ContentTypeResult.js +3 -3
- package/lib/Search/SearchResult.js +11 -11
- package/lib/Search/SearchResultSleeve.js +11 -11
- package/lib/all.css +1 -1
- package/package.json +17 -17
- package/src/CompetenceGoalTab/SearchButton.tsx +1 -1
- package/src/ErrorMessage/ErrorResourceAccessDenied.tsx +2 -2
- package/src/Figure/component.figure.scss +5 -2
- package/src/FileList/FileList.tsx +8 -0
- package/src/Filter/component.filter.scss +1 -1
- package/src/LearningPaths/LearningPathMenuIntro.tsx +1 -0
- package/src/LearningPaths/LearningPathSticky.tsx +2 -15
- package/src/Search/ContentTypeResult.tsx +2 -2
- package/src/Search/SearchResult.tsx +3 -3
- package/src/Search/SearchResultSleeve.tsx +3 -3
- package/src/Search/component.search-result.scss +1 -1
- package/src/all.scss +0 -1
|
@@ -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'), ";}
|
|
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,
|