@ndla/ui 3.3.7 → 3.3.12

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 (115) hide show
  1. package/es/Article/Article.js +23 -1
  2. package/es/Article/ArticleNotions.js +80 -32
  3. package/es/Breadcrumb/Breadcrumb.js +2 -1
  4. package/es/Breadcrumblist/Breadcrumblist.js +14 -10
  5. package/es/CloseButton/CloseButton.js +62 -0
  6. package/es/CloseButton/index.js +9 -0
  7. package/es/Frontpage/FrontpageAllSubjects.js +7 -7
  8. package/es/Frontpage/FrontpageProgramMenu.js +10 -10
  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 +214 -247
  14. package/es/NDLAFilm/NavigationArrow.js +13 -60
  15. package/es/NDLAFilm/SlideshowIndicator.js +16 -63
  16. package/es/NDLAFilm/interfaces.js +0 -0
  17. package/es/Programme/Programme.js +15 -8
  18. package/es/SearchTypeResult/SearchFieldHeader.js +5 -5
  19. package/es/SearchTypeResult/SearchHeader.js +9 -9
  20. package/es/SearchTypeResult/SearchItem.js +19 -19
  21. package/es/SearchTypeResult/SearchNotionItem.js +12 -12
  22. package/es/SearchTypeResult/SearchNotionsResult.js +9 -14
  23. package/es/Spinner/Spinner.js +3 -3
  24. package/es/index.js +2 -1
  25. package/es/locale/messages-en.js +10 -0
  26. package/es/locale/messages-nb.js +10 -0
  27. package/es/locale/messages-nn.js +10 -0
  28. package/lib/Article/Article.d.ts +3 -1
  29. package/lib/Article/Article.js +25 -3
  30. package/lib/Article/ArticleNotions.js +79 -30
  31. package/lib/Breadcrumb/Breadcrumb.js +2 -1
  32. package/lib/Breadcrumblist/Breadcrumblist.d.ts +2 -1
  33. package/lib/Breadcrumblist/Breadcrumblist.js +15 -10
  34. package/lib/CloseButton/CloseButton.d.ts +6 -0
  35. package/lib/CloseButton/CloseButton.js +69 -0
  36. package/lib/CloseButton/index.d.ts +9 -0
  37. package/lib/CloseButton/index.js +15 -0
  38. package/lib/Frontpage/FrontpageAllSubjects.d.ts +1 -1
  39. package/lib/Frontpage/FrontpageAllSubjects.js +7 -7
  40. package/lib/Frontpage/FrontpageProgramMenu.js +10 -10
  41. package/lib/MediaList/MediaList.d.ts +48 -0
  42. package/lib/MediaList/MediaList.js +24 -78
  43. package/lib/MediaList/index.d.ts +8 -0
  44. package/lib/MessageBox/MessageBox.d.ts +22 -6
  45. package/lib/MessageBox/MessageBox.js +146 -77
  46. package/lib/MessageBox/MessageBoxTag.d.ts +12 -0
  47. package/lib/MessageBox/MessageBoxTag.js +44 -0
  48. package/lib/MessageBox/index.d.ts +3 -1
  49. package/lib/MessageBox/index.js +22 -2
  50. package/lib/NDLAFilm/FilmSlideshow.d.ts +16 -0
  51. package/lib/NDLAFilm/FilmSlideshow.js +214 -248
  52. package/lib/NDLAFilm/NavigationArrow.d.ts +15 -0
  53. package/lib/NDLAFilm/NavigationArrow.js +20 -65
  54. package/lib/NDLAFilm/SlideshowIndicator.d.ts +15 -0
  55. package/lib/NDLAFilm/SlideshowIndicator.js +16 -69
  56. package/lib/NDLAFilm/interfaces.d.ts +10 -0
  57. package/lib/NDLAFilm/interfaces.js +1 -0
  58. package/lib/NDLAFilm/shapes.d.ts +15 -0
  59. package/lib/Programme/Programme.d.ts +2 -1
  60. package/lib/Programme/Programme.js +18 -9
  61. package/lib/SearchTypeResult/SearchFieldHeader.d.ts +3 -3
  62. package/lib/SearchTypeResult/SearchFieldHeader.js +5 -5
  63. package/lib/SearchTypeResult/SearchHeader.d.ts +3 -3
  64. package/lib/SearchTypeResult/SearchHeader.js +9 -9
  65. package/lib/SearchTypeResult/SearchItem.d.ts +2 -3
  66. package/lib/SearchTypeResult/SearchItem.js +19 -19
  67. package/lib/SearchTypeResult/SearchNotionItem.d.ts +1 -1
  68. package/lib/SearchTypeResult/SearchNotionItem.js +12 -12
  69. package/lib/SearchTypeResult/SearchNotionsResult.js +8 -13
  70. package/lib/SearchTypeResult/index.d.ts +1 -0
  71. package/lib/Spinner/Spinner.d.ts +3 -3
  72. package/lib/Spinner/Spinner.js +2 -2
  73. package/lib/index.d.ts +2 -1
  74. package/lib/index.js +23 -0
  75. package/lib/locale/messages-en.d.ts +10 -0
  76. package/lib/locale/messages-en.js +10 -0
  77. package/lib/locale/messages-nb.d.ts +10 -0
  78. package/lib/locale/messages-nb.js +10 -0
  79. package/lib/locale/messages-nn.d.ts +10 -0
  80. package/lib/locale/messages-nn.js +10 -0
  81. package/package.json +10 -10
  82. package/src/Article/Article.tsx +17 -0
  83. package/src/Article/ArticleNotions.tsx +10 -7
  84. package/src/Breadcrumb/Breadcrumb.tsx +1 -1
  85. package/src/Breadcrumblist/Breadcrumblist.tsx +5 -3
  86. package/src/CloseButton/CloseButton.tsx +40 -0
  87. package/src/CloseButton/index.ts +11 -0
  88. package/src/Frontpage/FrontpageAllSubjects.tsx +2 -2
  89. package/src/Frontpage/FrontpageProgramMenu.tsx +1 -0
  90. package/src/MediaList/MediaList.tsx +158 -0
  91. package/src/MediaList/{index.js → index.ts} +0 -0
  92. package/src/MessageBox/MessageBox.tsx +117 -96
  93. package/src/MessageBox/MessageBoxTag.tsx +35 -0
  94. package/src/MessageBox/index.ts +3 -1
  95. package/src/NDLAFilm/FilmSlideshow.tsx +265 -0
  96. package/src/NDLAFilm/NavigationArrow.tsx +42 -0
  97. package/src/NDLAFilm/SlideshowIndicator.tsx +40 -0
  98. package/src/NDLAFilm/interfaces.ts +10 -0
  99. package/src/NDLAFilm/{shapes.js → shapes.ts} +0 -0
  100. package/src/Programme/Programme.tsx +7 -3
  101. package/src/SearchTypeResult/SearchFieldHeader.tsx +3 -3
  102. package/src/SearchTypeResult/SearchHeader.tsx +3 -3
  103. package/src/SearchTypeResult/SearchItem.tsx +4 -5
  104. package/src/SearchTypeResult/SearchNotionItem.tsx +1 -2
  105. package/src/SearchTypeResult/SearchNotionsResult.tsx +3 -8
  106. package/src/SearchTypeResult/index.ts +2 -0
  107. package/src/Spinner/Spinner.tsx +9 -5
  108. package/src/index.ts +2 -1
  109. package/src/locale/messages-en.ts +14 -0
  110. package/src/locale/messages-nb.ts +14 -0
  111. package/src/locale/messages-nn.ts +14 -0
  112. package/src/MediaList/MediaList.jsx +0 -182
  113. package/src/NDLAFilm/FilmSlideshow.jsx +0 -277
  114. package/src/NDLAFilm/NavigationArrow.jsx +0 -46
  115. package/src/NDLAFilm/SlideshowIndicator.jsx +0 -43
@@ -78,7 +78,7 @@ var ItemWrapper = (0, _styledBase["default"])("div", {
78
78
  } : {
79
79
  name: "cgq59l",
80
80
  styles: "flex-direction:column;",
81
- 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"]} */",
81
+ 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"]} */",
82
82
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
83
  });
84
84
  var ItemHead = (0, _styledBase["default"])("div", {
@@ -90,19 +90,19 @@ var ItemHead = (0, _styledBase["default"])("div", {
90
90
  from: _core.breakpoints.desktop
91
91
  }), "{height:100px;}border:1px solid ", function (props) {
92
92
  return props.type && "".concat(resourceTypeColor(props.type), ";");
93
- }, ";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"]} */"));
93
+ }, ";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"]} */"));
94
94
  var ItemIcon = (0, _styledBase["default"])("div", {
95
95
  target: "e1hz9lam2",
96
96
  label: "ItemIcon"
97
97
  })("height:100%;background:#ccc;border-top-left-radius:5px;border-top-right-radius:5px;display:flex;justify-content:center;align-items:center;", function (props) {
98
98
  return props.type && "background: ".concat(resourceTypeColor(props.type), ";");
99
- }, 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"]} */");
99
+ }, 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"]} */");
100
100
  var ItemContent = (0, _styledBase["default"])("div", {
101
101
  target: "e1hz9lam3",
102
102
  label: "ItemContent"
103
103
  })("border:1px solid ", function (props) {
104
104
  return props.type && "".concat(resourceTypeColor(props.type), ";");
105
- }, ";border-top:0;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:", _core.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"]} */"));
105
+ }, ";border-top:0;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:", _core.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"]} */"));
106
106
  var ItemPillWrapper = (0, _styledBase["default"])("div", {
107
107
  target: "e1hz9lam4",
108
108
  label: "ItemPillWrapper"
@@ -112,25 +112,25 @@ var ItemPillWrapper = (0, _styledBase["default"])("div", {
112
112
  } : {
113
113
  name: "tvv90y",
114
114
  styles: "margin-top:8px;display:flex;flex-wrap:wrap;",
115
- 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"]} */",
115
+ 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"]} */",
116
116
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
117
117
  });
118
118
  var ItemPill = (0, _styledBase["default"])("div", {
119
119
  target: "e1hz9lam5",
120
120
  label: "ItemPill"
121
- })("display:inline-block;background:", _core.colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.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"]} */"));
121
+ })("display:inline-block;background:", _core.colors.brand.greyLightest, ";padding:2px 4px;border-radius:2px;", _core.fonts.sizes('12px', '20px'), ";font-weight:", _core.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"]} */"));
122
122
  var ItemTitle = (0, _styledBase["default"])("h3", {
123
123
  target: "e1hz9lam6",
124
124
  label: "ItemTitle"
125
- })("font-size:18px;line-height:24px;margin-top:", _core.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"]} */"));
125
+ })("font-size:18px;line-height:24px;margin-top:", _core.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"]} */"));
126
126
  var ItemText = (0, _styledBase["default"])("p", {
127
127
  target: "e1hz9lam7",
128
128
  label: "ItemText"
129
- })("font-size:15px;line-height:20px;margin-bottom:", _core.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"]} */"));
129
+ })("font-size:15px;line-height:20px;margin-bottom:", _core.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"]} */"));
130
130
  var BreadcrumbPath = (0, _styledBase["default"])("div", {
131
131
  target: "e1hz9lam8",
132
132
  label: "BreadcrumbPath"
133
- })("color:", _core.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"]} */"));
133
+ })("color:", _core.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"]} */"));
134
134
  var BreadcrumbItem = (0, _styledBase["default"])("span", {
135
135
  target: "e1hz9lam9",
136
136
  label: "BreadcrumbItem"
@@ -140,29 +140,29 @@ var BreadcrumbItem = (0, _styledBase["default"])("span", {
140
140
  } : {
141
141
  name: "l49p2b",
142
142
  styles: "display:inline-flex;align-items:center;flex-wrap:wrap;overflow-wrap:anywhere;",
143
- 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"]} */",
143
+ 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"]} */",
144
144
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
145
145
  });
146
146
  var ContextsWrapper = (0, _styledBase["default"])("div", {
147
147
  target: "e1hz9lam10",
148
148
  label: "ContextsWrapper"
149
- })("margin-top:", _core.spacing.small, ";button{", _core.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"]} */"));
149
+ })("margin-top:", _core.spacing.small, ";button{", _core.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"]} */"));
150
150
  var ModalHeader = (0, _styledBase["default"])("div", {
151
151
  target: "e1hz9lam11",
152
152
  label: "ModalHeader"
153
153
  })("display:flex;justify-content:space-between;align-items:center;padding:", _core.spacing.normal, " ", _core.spacing.small, ";", _core.mq.range({
154
154
  from: _core.breakpoints.tablet
155
- }), "{padding:", _core.spacing.normal, " ", _core.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"]} */"));
155
+ }), "{padding:", _core.spacing.normal, " ", _core.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"]} */"));
156
156
  var ModalHeading = (0, _styledBase["default"])("h2", {
157
157
  target: "e1hz9lam12",
158
158
  label: "ModalHeading"
159
- })("margin:0;", _core.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"]} */"));
159
+ })("margin:0;", _core.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"]} */"));
160
160
  var ModalContent = (0, _styledBase["default"])("div", {
161
161
  target: "e1hz9lam13",
162
162
  label: "ModalContent"
163
163
  })("padding:0 ", _core.spacing.small, " ", _core.spacing.normal, ";", _core.mq.range({
164
164
  from: _core.breakpoints.tablet
165
- }), "{padding:0 ", _core.spacing.large, " ", _core.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"]} */"));
165
+ }), "{padding:0 ", _core.spacing.large, " ", _core.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"]} */"));
166
166
  var ContextList = (0, _styledBase["default"])("ul", {
167
167
  target: "e1hz9lam14",
168
168
  label: "ContextList"
@@ -172,17 +172,17 @@ var ContextList = (0, _styledBase["default"])("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
  var ContextListItem = (0, _styledBase["default"])("li", {
179
179
  target: "e1hz9lam15",
180
180
  label: "ContextListItem"
181
- })("margin-bottom:", _core.spacing.normal, ";", _core.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"]} */"));
181
+ })("margin-bottom:", _core.spacing.normal, ";", _core.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"]} */"));
182
182
  var IconWrapper = (0, _styledBase["default"])("div", {
183
183
  target: "e1hz9lam16",
184
184
  label: "IconWrapper"
185
- })("margin-left:", _core.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"]} */"));
185
+ })("margin-left:", _core.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"]} */"));
186
186
 
187
187
  var SearchItem = function SearchItem(_ref) {
188
188
  var item = _ref.item,
@@ -199,7 +199,7 @@ var SearchItem = function SearchItem(_ref) {
199
199
  img = _item$img === void 0 ? null : _item$img,
200
200
  _item$labels = item.labels,
201
201
  labels = _item$labels === void 0 ? [] : _item$labels;
202
- var mainContext = contexts[0];
202
+ var mainContext = contexts === null || contexts === void 0 ? void 0 : contexts[0];
203
203
 
204
204
  var Breadcrumb = function Breadcrumb(_ref2) {
205
205
  var breadcrumb = _ref2.breadcrumb,
@@ -236,7 +236,7 @@ var SearchItem = function SearchItem(_ref) {
236
236
  to: url
237
237
  }, title)), item.children, (0, _core2.jsx)(ItemText, null, (0, _htmlReactParser["default"])(ingress)), mainContext && (0, _core2.jsx)(Breadcrumb, {
238
238
  breadcrumb: mainContext.breadcrumb
239
- }), contexts.length > 1 && (0, _core2.jsx)(ContextsWrapper, null, (0, _core2.jsx)(_modal["default"], {
239
+ }), contexts && contexts.length > 1 && (0, _core2.jsx)(ContextsWrapper, null, (0, _core2.jsx)(_modal["default"], {
240
240
  activateButton: (0, _core2.jsx)(_button["default"], {
241
241
  link: true
242
242
  }, t('searchPage.contextModal.button', {