@ndla/ui 3.3.8 → 3.3.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (103) hide show
  1. package/es/Article/Article.js +23 -1
  2. package/es/Article/ArticleNotions.js +80 -32
  3. package/es/Breadcrumblist/Breadcrumblist.js +14 -10
  4. package/es/CloseButton/CloseButton.js +62 -0
  5. package/es/CloseButton/index.js +9 -0
  6. package/es/Frontpage/FrontpageAllSubjects.js +7 -7
  7. package/es/Frontpage/FrontpageProgramMenu.js +10 -10
  8. package/es/Frontpage/FrontpageSearch.js +2 -4
  9. package/es/MediaList/MediaList.js +22 -73
  10. package/es/MessageBox/MessageBox.js +146 -78
  11. package/es/MessageBox/MessageBoxTag.js +37 -0
  12. package/es/MessageBox/index.js +3 -1
  13. package/es/NDLAFilm/FilmSlideshow.js +2 -1
  14. package/es/NDLAFilm/shapes.js +10 -0
  15. package/es/Programme/Programme.js +15 -8
  16. package/es/Search/SearchResultSleeve.js +12 -15
  17. package/es/SearchTypeResult/SearchFieldHeader.js +5 -5
  18. package/es/SearchTypeResult/SearchHeader.js +9 -9
  19. package/es/SearchTypeResult/SearchItem.js +19 -19
  20. package/es/SearchTypeResult/SearchNotionItem.js +12 -12
  21. package/es/SearchTypeResult/SearchNotionsResult.js +9 -14
  22. package/es/index.js +2 -1
  23. package/es/locale/messages-en.js +10 -0
  24. package/es/locale/messages-nb.js +10 -0
  25. package/es/locale/messages-nn.js +10 -0
  26. package/lib/Article/Article.d.ts +3 -1
  27. package/lib/Article/Article.js +25 -3
  28. package/lib/Article/ArticleNotions.js +79 -30
  29. package/lib/Breadcrumblist/Breadcrumblist.d.ts +2 -1
  30. package/lib/Breadcrumblist/Breadcrumblist.js +15 -10
  31. package/lib/CloseButton/CloseButton.d.ts +6 -0
  32. package/lib/CloseButton/CloseButton.js +69 -0
  33. package/lib/CloseButton/index.d.ts +9 -0
  34. package/lib/CloseButton/index.js +15 -0
  35. package/lib/Frontpage/FrontpageAllSubjects.d.ts +1 -1
  36. package/lib/Frontpage/FrontpageAllSubjects.js +7 -7
  37. package/lib/Frontpage/FrontpageProgramMenu.js +10 -10
  38. package/lib/Frontpage/FrontpageSearch.d.ts +3 -5
  39. package/lib/Frontpage/FrontpageSearch.js +2 -4
  40. package/lib/MediaList/MediaList.d.ts +48 -0
  41. package/lib/MediaList/MediaList.js +24 -78
  42. package/lib/MediaList/index.d.ts +8 -0
  43. package/lib/MessageBox/MessageBox.d.ts +22 -6
  44. package/lib/MessageBox/MessageBox.js +146 -77
  45. package/lib/MessageBox/MessageBoxTag.d.ts +12 -0
  46. package/lib/MessageBox/MessageBoxTag.js +44 -0
  47. package/lib/MessageBox/index.d.ts +3 -1
  48. package/lib/MessageBox/index.js +22 -2
  49. package/lib/NDLAFilm/shapes.d.ts +10 -0
  50. package/lib/NDLAFilm/shapes.js +14 -1
  51. package/lib/Programme/Programme.d.ts +2 -1
  52. package/lib/Programme/Programme.js +18 -9
  53. package/lib/Search/SearchResultSleeve.d.ts +4 -6
  54. package/lib/Search/SearchResultSleeve.js +10 -11
  55. package/lib/SearchTypeResult/SearchFieldHeader.d.ts +3 -3
  56. package/lib/SearchTypeResult/SearchFieldHeader.js +5 -5
  57. package/lib/SearchTypeResult/SearchHeader.d.ts +3 -3
  58. package/lib/SearchTypeResult/SearchHeader.js +9 -9
  59. package/lib/SearchTypeResult/SearchItem.d.ts +2 -3
  60. package/lib/SearchTypeResult/SearchItem.js +19 -19
  61. package/lib/SearchTypeResult/SearchNotionItem.d.ts +1 -1
  62. package/lib/SearchTypeResult/SearchNotionItem.js +12 -12
  63. package/lib/SearchTypeResult/SearchNotionsResult.js +8 -13
  64. package/lib/SearchTypeResult/index.d.ts +1 -0
  65. package/lib/index.d.ts +2 -1
  66. package/lib/index.js +23 -0
  67. package/lib/locale/messages-en.d.ts +10 -0
  68. package/lib/locale/messages-en.js +10 -0
  69. package/lib/locale/messages-nb.d.ts +10 -0
  70. package/lib/locale/messages-nb.js +10 -0
  71. package/lib/locale/messages-nn.d.ts +10 -0
  72. package/lib/locale/messages-nn.js +10 -0
  73. package/lib/types.d.ts +2 -2
  74. package/package.json +9 -9
  75. package/src/Article/Article.tsx +17 -0
  76. package/src/Article/ArticleNotions.tsx +10 -7
  77. package/src/Breadcrumblist/Breadcrumblist.tsx +5 -3
  78. package/src/CloseButton/CloseButton.tsx +40 -0
  79. package/src/CloseButton/index.ts +11 -0
  80. package/src/Frontpage/FrontpageAllSubjects.tsx +2 -2
  81. package/src/Frontpage/FrontpageProgramMenu.tsx +1 -0
  82. package/src/Frontpage/FrontpageSearch.tsx +3 -7
  83. package/src/MediaList/MediaList.tsx +158 -0
  84. package/src/MediaList/{index.js → index.ts} +0 -0
  85. package/src/MessageBox/MessageBox.tsx +117 -96
  86. package/src/MessageBox/MessageBoxTag.tsx +35 -0
  87. package/src/MessageBox/index.ts +3 -1
  88. package/src/NDLAFilm/FilmSlideshow.tsx +1 -0
  89. package/src/NDLAFilm/shapes.ts +11 -0
  90. package/src/Programme/Programme.tsx +7 -3
  91. package/src/Search/SearchResultSleeve.tsx +7 -19
  92. package/src/SearchTypeResult/SearchFieldHeader.tsx +3 -3
  93. package/src/SearchTypeResult/SearchHeader.tsx +3 -3
  94. package/src/SearchTypeResult/SearchItem.tsx +4 -5
  95. package/src/SearchTypeResult/SearchNotionItem.tsx +1 -2
  96. package/src/SearchTypeResult/SearchNotionsResult.tsx +3 -8
  97. package/src/SearchTypeResult/index.ts +2 -0
  98. package/src/index.ts +2 -1
  99. package/src/locale/messages-en.ts +14 -0
  100. package/src/locale/messages-nb.ts +14 -0
  101. package/src/locale/messages-nn.ts +14 -0
  102. package/src/types.ts +2 -2
  103. package/src/MediaList/MediaList.jsx +0 -182
@@ -64,7 +64,7 @@ var ItemWrapper = _styled("div", {
64
64
  } : {
65
65
  name: "cgq59l",
66
66
  styles: "flex-direction:column;",
67
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuD8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
67
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuD8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
68
68
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
69
69
  });
70
70
 
@@ -77,21 +77,21 @@ var ItemHead = _styled("div", {
77
77
  from: breakpoints.desktop
78
78
  }), "{height:100px;}border:1px solid ", function (props) {
79
79
  return props.type && "".concat(resourceTypeColor(props.type), ";");
80
- }, ";border-bottom:0;border-top-left-radius:5px;border-top-right-radius:5px;img{border-top-left-radius:5px;border-top-right-radius:5px;width:100%;height:100%;object-fit:cover;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA2D0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
80
+ }, ";border-bottom:0;border-top-left-radius:5px;border-top-right-radius:5px;img{border-top-left-radius:5px;border-top-right-radius:5px;width:100%;height:100%;object-fit:cover;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA2D0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
81
81
 
82
82
  var ItemIcon = _styled("div", {
83
83
  target: "e1hz9lam2",
84
84
  label: "ItemIcon"
85
85
  })("height:100%;background:#ccc;border-top-left-radius:5px;border-top-right-radius:5px;display:flex;justify-content:center;align-items:center;", function (props) {
86
86
  return props.type && "background: ".concat(resourceTypeColor(props.type), ";");
87
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoF0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */");
87
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoF0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */");
88
88
 
89
89
  var ItemContent = _styled("div", {
90
90
  target: "e1hz9lam3",
91
91
  label: "ItemContent"
92
92
  })("border:1px solid ", function (props) {
93
93
  return props.type && "".concat(resourceTypeColor(props.type), ";");
94
- }, ";border-top:0;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+F6C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
94
+ }, ";border-top:0;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:", spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+F6C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
95
95
 
96
96
  var ItemPillWrapper = _styled("div", {
97
97
  target: "e1hz9lam4",
@@ -102,29 +102,29 @@ var ItemPillWrapper = _styled("div", {
102
102
  } : {
103
103
  name: "tvv90y",
104
104
  styles: "margin-top:8px;display:flex;flex-wrap:wrap;",
105
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
106
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
107
  });
108
108
 
109
109
  var ItemPill = _styled("div", {
110
110
  target: "e1hz9lam5",
111
111
  label: "ItemPill"
112
- })("display:inline-block;background:", colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", fonts.sizes('12px', '20px'), ";font-weight:", fonts.weight.semibold, ";margin:8px 4px 4px 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4G2B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
112
+ })("display:inline-block;background:", colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", fonts.sizes('12px', '20px'), ";font-weight:", fonts.weight.semibold, ";margin:8px 4px 4px 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4G2B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
113
113
 
114
114
  var ItemTitle = _styled("h3", {
115
115
  target: "e1hz9lam6",
116
116
  label: "ItemTitle"
117
- })("font-size:18px;line-height:24px;margin-top:", spacing.small, ";font-weight:600;overflow-wrap:anywhere;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAsH2B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
117
+ })("font-size:18px;line-height:24px;margin-top:", spacing.small, ";font-weight:600;overflow-wrap:anywhere;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAsH2B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
118
118
 
119
119
  var ItemText = _styled("p", {
120
120
  target: "e1hz9lam7",
121
121
  label: "ItemText"
122
- })("font-size:15px;line-height:20px;margin-bottom:", spacing.small, ";word-break:break-word;overflow-wrap:anywhere;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA6HyB","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
122
+ })("font-size:15px;line-height:20px;margin-bottom:", spacing.small, ";word-break:break-word;overflow-wrap:anywhere;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA6HyB","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
123
123
 
124
124
  var BreadcrumbPath = _styled("div", {
125
125
  target: "e1hz9lam8",
126
126
  label: "BreadcrumbPath"
127
- })("color:", colors.text.light, ";font-size:16px;line-height:24px;display:flex;align-items:center;flex-wrap:wrap;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoIiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
127
+ })("color:", colors.text.light, ";font-size:16px;line-height:24px;display:flex;align-items:center;flex-wrap:wrap;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoIiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
128
128
 
129
129
  var BreadcrumbItem = _styled("span", {
130
130
  target: "e1hz9lam9",
@@ -135,33 +135,33 @@ var BreadcrumbItem = _styled("span", {
135
135
  } : {
136
136
  name: "l49p2b",
137
137
  styles: "display:inline-flex;align-items:center;flex-wrap:wrap;overflow-wrap:anywhere;",
138
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA6IkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
138
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA6IkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
139
139
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
140
140
  });
141
141
 
142
142
  var ContextsWrapper = _styled("div", {
143
143
  target: "e1hz9lam10",
144
144
  label: "ContextsWrapper"
145
- })("margin-top:", spacing.small, ";button{", fonts.sizes('16px', '24px'), ";box-shadow:none;&:hover{box-shadow:inset 0 -1px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoJkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
145
+ })("margin-top:", spacing.small, ";button{", fonts.sizes('16px', '24px'), ";box-shadow:none;&:hover{box-shadow:inset 0 -1px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoJkC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
146
146
 
147
147
  var ModalHeader = _styled("div", {
148
148
  target: "e1hz9lam11",
149
149
  label: "ModalHeader"
150
150
  })("display:flex;justify-content:space-between;align-items:center;padding:", spacing.normal, " ", spacing.small, ";", mq.range({
151
151
  from: breakpoints.tablet
152
- }), "{padding:", spacing.normal, " ", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+J8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
152
+ }), "{padding:", spacing.normal, " ", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+J8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
153
153
 
154
154
  var ModalHeading = _styled("h2", {
155
155
  target: "e1hz9lam12",
156
156
  label: "ModalHeading"
157
- })("margin:0;", fonts.sizes('16px', '20px'), ";font-weight:600;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAyK8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
157
+ })("margin:0;", fonts.sizes('16px', '20px'), ";font-weight:600;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAyK8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
158
158
 
159
159
  var ModalContent = _styled("div", {
160
160
  target: "e1hz9lam13",
161
161
  label: "ModalContent"
162
162
  })("padding:0 ", spacing.small, " ", spacing.normal, ";", mq.range({
163
163
  from: breakpoints.tablet
164
- }), "{padding:0 ", spacing.large, " ", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+K+B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
164
+ }), "{padding:0 ", spacing.large, " ", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA+K+B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
165
165
 
166
166
  var ContextList = _styled("ul", {
167
167
  target: "e1hz9lam14",
@@ -172,19 +172,19 @@ var ContextList = _styled("ul", {
172
172
  } : {
173
173
  name: "rxgulu",
174
174
  styles: "margin:0;padding:0;list-style:none;",
175
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAsL6B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
175
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAsL6B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */",
176
176
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
177
177
  });
178
178
 
179
179
  var ContextListItem = _styled("li", {
180
180
  target: "e1hz9lam15",
181
181
  label: "ContextListItem"
182
- })("margin-bottom:", spacing.normal, ";", fonts.sizes('16px', '28px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA2LiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
182
+ })("margin-bottom:", spacing.normal, ";", fonts.sizes('16px', '28px'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA2LiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
183
183
 
184
184
  var IconWrapper = _styled("div", {
185
185
  target: "e1hz9lam16",
186
186
  label: "IconWrapper"
187
- })("margin-left:", spacing.small, ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgM8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts: context[];\n  image: React.ReactNode | null;\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
187
+ })("margin-left:", spacing.small, ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgM8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-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 React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n// @ts-ignore\nimport { ChevronRight, Additional, Core } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport Button from '@ndla/button';\n// @ts-ignore\nimport Modal, { ModalCloseButton } from '@ndla/modal';\n\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { ContentType } from './SearchTypeResult';\n// @ts-ignore\nimport constants from '../model';\n\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\n\nconst { contentTypes } = constants;\n\nconst resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return null;\n  }\n};\n\ntype ItemTypeProps = {\n  type?: ContentType;\n};\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n`;\n\nconst ItemHead = styled.div<ItemTypeProps>`\n  height: 200px;\n  position: relative;\n  a {\n    box-shadow: none;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 160px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 100px;\n  }\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-bottom: 0;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  img {\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nconst ItemIcon = styled.div<ItemTypeProps>`\n  height: 100%;\n  background: #ccc;\n  border-top-left-radius: 5px;\n  border-top-right-radius: 5px;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  ${(props) => props.type && `background: ${resourceTypeColor(props.type)};`}\n`;\n\nconst ItemContent = styled.div<ItemTypeProps>`\n  border: 1px solid ${(props) => props.type && `${resourceTypeColor(props.type)};`};\n  border-top: 0;\n  border-bottom-left-radius: 5px;\n  border-bottom-right-radius: 5px;\n  padding: ${spacing.small};\n`;\n\nconst ItemPillWrapper = styled.div`\n  margin-top: 8px;\n  display: flex;\n  flex-wrap: wrap;\n`;\nconst ItemPill = styled.div`\n  display: inline-block;\n  background: ${colors.brand.greyLightest};\n  padding: 2px 4px;\n  border-radius: 2px;\n  ${fonts.sizes('12px', '20px')};\n  font-weight: ${fonts.weight.semibold};\n  margin: 8px 4px 4px 0;\n`;\n\nconst ItemTitle = styled.h3`\n  font-size: 18px;\n  line-height: 24px;\n  margin-top: ${spacing.small};\n  font-weight: 600;\n  overflow-wrap: anywhere;\n`;\nconst ItemText = styled.p`\n  font-size: 15px;\n  line-height: 20px;\n  margin-bottom: ${spacing.small};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n`;\nconst BreadcrumbPath = styled.div`\n  color: ${colors.text.light};\n  font-size: 16px;\n  line-height: 24px;\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n`;\n\nconst BreadcrumbItem = styled.span`\n  display: inline-flex;\n  align-items: center;\n  flex-wrap: wrap;\n  overflow-wrap: anywhere;\n`;\n\nconst ContextsWrapper = styled.div`\n  margin-top: ${spacing.small};\n  button {\n    ${fonts.sizes('16px', '24px')};\n    box-shadow: none;\n    &:hover {\n      box-shadow: inset 0 -1px;\n    }\n  }\n`;\n\nconst ModalHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: ${spacing.normal} ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.normal} ${spacing.large};\n  }\n`;\n\nconst ModalHeading = styled.h2`\n  margin: 0;\n  ${fonts.sizes('16px', '20px')};\n  font-weight: 600;\n`;\n\nconst ModalContent = styled.div`\n  padding: 0 ${spacing.small} ${spacing.normal};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: 0 ${spacing.large} ${spacing.normal};\n  }\n`;\n\nconst ContextList = styled.ul`\n  margin: 0;\n  padding: 0;\n  list-style: none;\n`;\nconst ContextListItem = styled.li`\n  margin-bottom: ${spacing.normal};\n  ${fonts.sizes('16px', '28px')};\n`;\n\nconst IconWrapper = styled.div`\n  margin-left: ${spacing.small};\n  display: flex;\n  align-items: center;\n`;\n\ntype context = {\n  breadcrumb: string[];\n  url: string;\n  isAdditional?: boolean;\n};\n\nexport type SearchItemType = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: context[];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  children?: React.ReactNode;\n};\ntype Props = {\n  item: SearchItemType;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: Props) => {\n  const { t } = useTranslation();\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n  const mainContext = contexts?.[0];\n\n  const Breadcrumb = ({ breadcrumb, children }: { breadcrumb: string[]; children?: React.ReactNode }) => (\n    <BreadcrumbPath>\n      {breadcrumb.map((breadcrumbItem: string, i: number) => {\n        return (\n          <BreadcrumbItem key={`${breadcrumbItem}-${item.id}`}>\n            <span>{breadcrumbItem}</span>\n            {i !== breadcrumb.length - 1 && <ChevronRight />}\n          </BreadcrumbItem>\n        );\n      })}\n      {children}\n    </BreadcrumbPath>\n  );\n\n  return (\n    <>\n      <ItemWrapper>\n        <ItemHead type={type}>\n          {img ? (\n            <SafeLink to={url}>\n              <img src={img.url} alt={img.alt} />\n            </SafeLink>\n          ) : (\n            <SafeLink to={url}>\n              {type && (\n                <ItemIcon type={type}>\n                  <ContentTypeBadge type={type} size=\"small\" border={false} />\n                </ItemIcon>\n              )}\n            </SafeLink>\n          )}\n        </ItemHead>\n        <ItemContent type={type}>\n          {labels.length > 0 && (\n            <ItemPillWrapper>\n              {labels.map((label) => (\n                <ItemPill key={label}>{label}</ItemPill>\n              ))}\n            </ItemPillWrapper>\n          )}\n          <ItemTitle>\n            <SafeLink to={url}>{title}</SafeLink>\n          </ItemTitle>\n          {item.children}\n          <ItemText>{parse(ingress)}</ItemText>\n          {mainContext && <Breadcrumb breadcrumb={mainContext.breadcrumb} />}\n          {contexts && contexts.length > 1 && (\n            <ContextsWrapper>\n              <Modal\n                activateButton={\n                  <Button link>\n                    {t('searchPage.contextModal.button', {\n                      count: contexts.length - 1,\n                    })}\n                  </Button>\n                }\n                animation=\"subtle\"\n                animationDuration={50}\n                backgroundColor=\"white\"\n                size=\"medium\">\n                {(onClose: () => void) => (\n                  <>\n                    <ModalHeader>\n                      <ModalHeading>{t('searchPage.contextModal.heading')}</ModalHeading>\n                      <ModalCloseButton onClick={onClose} title={t('searchPage.close')} />\n                    </ModalHeader>\n                    <ModalContent>\n                      <ContextList>\n                        {contexts.map((context) => (\n                          <ContextListItem key={context.url}>\n                            <SafeLink to={context.url}>{title}</SafeLink>\n                            <Breadcrumb breadcrumb={context.breadcrumb}>\n                              <IconWrapper>\n                                {context.isAdditional ? (\n                                  <Additional style={{ width: '22px', height: '22px' }} />\n                                ) : (\n                                  <Core style={{ width: '22px', height: '22px' }} />\n                                )}\n                              </IconWrapper>\n                            </Breadcrumb>\n                          </ContextListItem>\n                        ))}\n                      </ContextList>\n                    </ModalContent>\n                  </>\n                )}\n              </Modal>\n            </ContextsWrapper>\n          )}\n        </ItemContent>\n      </ItemWrapper>\n    </>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
188
188
 
189
189
  var SearchItem = function SearchItem(_ref) {
190
190
  var item = _ref.item,
@@ -201,7 +201,7 @@ var SearchItem = function SearchItem(_ref) {
201
201
  img = _item$img === void 0 ? null : _item$img,
202
202
  _item$labels = item.labels,
203
203
  labels = _item$labels === void 0 ? [] : _item$labels;
204
- var mainContext = contexts[0];
204
+ var mainContext = contexts === null || contexts === void 0 ? void 0 : contexts[0];
205
205
 
206
206
  var Breadcrumb = function Breadcrumb(_ref2) {
207
207
  var breadcrumb = _ref2.breadcrumb,
@@ -238,7 +238,7 @@ var SearchItem = function SearchItem(_ref) {
238
238
  to: url
239
239
  }, title)), item.children, ___EmotionJSX(ItemText, null, parse(ingress)), mainContext && ___EmotionJSX(Breadcrumb, {
240
240
  breadcrumb: mainContext.breadcrumb
241
- }), contexts.length > 1 && ___EmotionJSX(ContextsWrapper, null, ___EmotionJSX(Modal, {
241
+ }), contexts && contexts.length > 1 && ___EmotionJSX(ContextsWrapper, null, ___EmotionJSX(Modal, {
242
242
  activateButton: ___EmotionJSX(Button, {
243
243
  link: true
244
244
  }, t('searchPage.contextModal.button', {