@ndla/ui 5.0.0 → 6.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/es/Breadcrumblist/Breadcrumblist.js +16 -9
  2. package/es/ContentPlaceholder/ContentPlaceholder.js +51 -0
  3. package/es/ContentPlaceholder/index.js +9 -0
  4. package/es/FactBox/FactBox.js +14 -31
  5. package/es/Frontpage/FrontpageSearch.js +10 -3
  6. package/es/Masthead/Masthead.js +9 -8
  7. package/es/Masthead/index.js +2 -1
  8. package/es/Masthead/utils.js +46 -0
  9. package/es/MessageBox/MessageBox.js +13 -7
  10. package/es/Notion/FigureNotion.js +3 -1
  11. package/es/Search/ContentTypeResult.js +4 -2
  12. package/es/Search/SearchField.js +5 -4
  13. package/es/Search/SearchResultSleeve.js +12 -10
  14. package/es/SearchTypeResult/SearchItem.js +8 -8
  15. package/es/all.css +1 -1
  16. package/es/index.js +2 -1
  17. package/lib/Breadcrumblist/Breadcrumblist.js +17 -9
  18. package/lib/ContentPlaceholder/ContentPlaceholder.d.ts +9 -0
  19. package/lib/ContentPlaceholder/ContentPlaceholder.js +54 -0
  20. package/lib/ContentPlaceholder/index.d.ts +9 -0
  21. package/lib/ContentPlaceholder/index.js +20 -0
  22. package/lib/FactBox/FactBox.js +14 -37
  23. package/lib/Frontpage/FrontpageSearch.js +10 -3
  24. package/lib/Masthead/Masthead.d.ts +3 -3
  25. package/lib/Masthead/Masthead.js +10 -8
  26. package/lib/Masthead/index.d.ts +2 -1
  27. package/lib/Masthead/index.js +14 -0
  28. package/lib/Masthead/utils.d.ts +11 -0
  29. package/lib/Masthead/utils.js +53 -0
  30. package/lib/MessageBox/MessageBox.d.ts +2 -1
  31. package/lib/MessageBox/MessageBox.js +13 -7
  32. package/lib/Notion/FigureNotion.js +3 -1
  33. package/lib/Search/ContentTypeResult.js +4 -2
  34. package/lib/Search/SearchField.js +5 -4
  35. package/lib/Search/SearchResultSleeve.js +12 -10
  36. package/lib/SearchTypeResult/SearchItem.js +8 -8
  37. package/lib/all.css +1 -1
  38. package/lib/index.d.ts +2 -1
  39. package/lib/index.js +23 -0
  40. package/package.json +13 -13
  41. package/src/Breadcrumblist/Breadcrumblist.tsx +12 -3
  42. package/src/ContentPlaceholder/ContentPlaceholder.tsx +68 -0
  43. package/src/ContentPlaceholder/index.ts +11 -0
  44. package/src/FactBox/FactBox.tsx +8 -10
  45. package/src/FactBox/component.factbox.scss +12 -0
  46. package/src/Frontpage/FrontpageSearch.tsx +7 -0
  47. package/src/Masthead/Masthead.tsx +7 -6
  48. package/src/Masthead/component.masthead.scss +3 -62
  49. package/src/Masthead/index.ts +3 -1
  50. package/src/Masthead/utils.ts +33 -0
  51. package/src/MessageBox/MessageBox.tsx +5 -1
  52. package/src/Notion/FigureNotion.tsx +25 -23
  53. package/src/Search/ContentTypeResult.tsx +3 -1
  54. package/src/Search/SearchField.jsx +2 -1
  55. package/src/Search/SearchResultSleeve.tsx +8 -2
  56. package/src/SearchTypeResult/SearchItem.tsx +0 -1
  57. package/src/index.ts +2 -1
@@ -69,13 +69,13 @@ var Container = (0, _styledBase["default"])("div", {
69
69
  } : {
70
70
  name: "1f9iwsz",
71
71
  styles: "display:flex;height:400px;align-items:center;justify-content:center;",
72
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiD4B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
72
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiD4B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
73
73
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
74
74
  });
75
75
  var ItemWrapper = (0, _styledBase["default"])("div", {
76
76
  target: "e1hz9lam1",
77
77
  label: "ItemWrapper"
78
- })("flex-direction:column;overflow:hidden;display:flex;width:100%;height:100%;border:1px solid ", _core.colors.brand.neutral7, ";border-radius:5px;transition:all ", _core.animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", _core.spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", _core.colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwD8B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
78
+ })("flex-direction:column;display:flex;width:100%;height:100%;border:1px solid ", _core.colors.brand.neutral7, ";border-radius:5px;transition:all ", _core.animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", _core.spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", _core.colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwD8B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
79
79
  var ItemLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
80
80
  target: "e1hz9lam2",
81
81
  label: "ItemLink"
@@ -85,35 +85,35 @@ var ItemLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
85
85
  } : {
86
86
  name: "lqgaa6",
87
87
  styles: "box-shadow:none;color:unset;text-decoration:none;display:flex;flex-direction:column;position:relative;min-height:0;flex:1;",
88
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwGiC","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
88
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGiC","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
89
89
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
90
  });
91
91
  var TextWrapper = (0, _styledBase["default"])("div", {
92
92
  target: "e1hz9lam3",
93
93
  label: "TextWrapper"
94
- })("padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAmH8B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
94
+ })("padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAkH8B","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
95
95
  var ItemTitleWrapper = (0, _styledBase["default"])("div", {
96
96
  target: "e1hz9lam4",
97
97
  label: "ItemTitleWrapper"
98
98
  })("transition:all ", _core.animations.durations.fast, " ease-in-out;margin-top:", _core.spacing.small, ";", function (props) {
99
99
  return props.isTopic && "".concat(ItemWrapper, ":hover & {\n padding-left:2px; padding-right: 2px;}");
100
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4HkD","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
100
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA2HkD","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
101
101
  var ItemTitle = (0, _styledBase["default"])("h3", {
102
102
  target: "e1hz9lam5",
103
103
  label: "ItemTitle"
104
104
  })(_core.fonts.sizes('24px', '28px'), ";color:", _core.colors.brand.primary, ";", function (props) {
105
105
  return props.isTopic && "margin-bottom: ".concat(_core.spacing.small, ";");
106
- }, ";font-weight:", _core.fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAqI0C","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
106
+ }, ";font-weight:", _core.fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAoI0C","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
107
107
  var ItemText = (0, _styledBase["default"])("div", {
108
108
  target: "e1hz9lam6",
109
109
  label: "ItemText"
110
110
  })("overflow:hidden;", _core.fonts.sizes('16px', '24px'), ";word-break:break-word;overflow-wrap:anywhere;transition:all ", _core.animations.durations.fast, " ease-in-out;margin-top:", _core.spacing.small, ";", function (props) {
111
111
  return props.isTopic && "\n ".concat(_core.fonts.sizes('18px', '28px'), ";\n ").concat(ItemWrapper, ":hover & {\n padding-left: 2px;\n padding-right: 2px;\n }");
112
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiJ0C","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
112
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgJ0C","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
113
113
  var ContextWrapper = (0, _styledBase["default"])("div", {
114
114
  target: "e1hz9lam7",
115
115
  label: "ContextWrapper"
116
- })("background:white;z-index:1;padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);padding-bottom:calc(", _core.spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAkKiC","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  overflow: hidden;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
116
+ })("background:white;z-index:1;padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);padding-bottom:calc(", _core.spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiKiC","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\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const 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 '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n  }\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    ${ItemWrapper}:hover & {\n    padding-left: 2px;\n    padding-right: 2px;\n  }`};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
117
117
 
118
118
  var SearchItem = function SearchItem(_ref) {
119
119
  var item = _ref.item,