@ndla/ui 3.3.7 → 3.3.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. package/es/Article/Article.js +23 -1
  2. package/es/Article/ArticleNotions.js +80 -32
  3. package/es/Breadcrumb/Breadcrumb.js +2 -1
  4. package/es/Breadcrumblist/Breadcrumblist.js +14 -10
  5. package/es/CloseButton/CloseButton.js +62 -0
  6. package/es/CloseButton/index.js +9 -0
  7. package/es/Frontpage/FrontpageAllSubjects.js +7 -7
  8. package/es/Frontpage/FrontpageProgramMenu.js +10 -10
  9. package/es/MediaList/MediaList.js +22 -73
  10. package/es/MessageBox/MessageBox.js +146 -78
  11. package/es/MessageBox/MessageBoxTag.js +37 -0
  12. package/es/MessageBox/index.js +3 -1
  13. package/es/NDLAFilm/FilmSlideshow.js +214 -247
  14. package/es/NDLAFilm/NavigationArrow.js +13 -60
  15. package/es/NDLAFilm/SlideshowIndicator.js +16 -63
  16. package/es/NDLAFilm/interfaces.js +0 -0
  17. package/es/Programme/Programme.js +15 -8
  18. package/es/SearchTypeResult/SearchFieldHeader.js +5 -5
  19. package/es/SearchTypeResult/SearchHeader.js +9 -9
  20. package/es/SearchTypeResult/SearchItem.js +19 -19
  21. package/es/SearchTypeResult/SearchNotionItem.js +12 -12
  22. package/es/SearchTypeResult/SearchNotionsResult.js +9 -14
  23. package/es/Spinner/Spinner.js +3 -3
  24. package/es/index.js +2 -1
  25. package/es/locale/messages-en.js +10 -0
  26. package/es/locale/messages-nb.js +10 -0
  27. package/es/locale/messages-nn.js +10 -0
  28. package/lib/Article/Article.d.ts +3 -1
  29. package/lib/Article/Article.js +25 -3
  30. package/lib/Article/ArticleNotions.js +79 -30
  31. package/lib/Breadcrumb/Breadcrumb.js +2 -1
  32. package/lib/Breadcrumblist/Breadcrumblist.d.ts +2 -1
  33. package/lib/Breadcrumblist/Breadcrumblist.js +15 -10
  34. package/lib/CloseButton/CloseButton.d.ts +6 -0
  35. package/lib/CloseButton/CloseButton.js +69 -0
  36. package/lib/CloseButton/index.d.ts +9 -0
  37. package/lib/CloseButton/index.js +15 -0
  38. package/lib/Frontpage/FrontpageAllSubjects.d.ts +1 -1
  39. package/lib/Frontpage/FrontpageAllSubjects.js +7 -7
  40. package/lib/Frontpage/FrontpageProgramMenu.js +10 -10
  41. package/lib/MediaList/MediaList.d.ts +48 -0
  42. package/lib/MediaList/MediaList.js +24 -78
  43. package/lib/MediaList/index.d.ts +8 -0
  44. package/lib/MessageBox/MessageBox.d.ts +22 -6
  45. package/lib/MessageBox/MessageBox.js +146 -77
  46. package/lib/MessageBox/MessageBoxTag.d.ts +12 -0
  47. package/lib/MessageBox/MessageBoxTag.js +44 -0
  48. package/lib/MessageBox/index.d.ts +3 -1
  49. package/lib/MessageBox/index.js +22 -2
  50. package/lib/NDLAFilm/FilmSlideshow.d.ts +16 -0
  51. package/lib/NDLAFilm/FilmSlideshow.js +214 -248
  52. package/lib/NDLAFilm/NavigationArrow.d.ts +15 -0
  53. package/lib/NDLAFilm/NavigationArrow.js +20 -65
  54. package/lib/NDLAFilm/SlideshowIndicator.d.ts +15 -0
  55. package/lib/NDLAFilm/SlideshowIndicator.js +16 -69
  56. package/lib/NDLAFilm/interfaces.d.ts +10 -0
  57. package/lib/NDLAFilm/interfaces.js +1 -0
  58. package/lib/NDLAFilm/shapes.d.ts +15 -0
  59. package/lib/Programme/Programme.d.ts +2 -1
  60. package/lib/Programme/Programme.js +18 -9
  61. package/lib/SearchTypeResult/SearchFieldHeader.d.ts +3 -3
  62. package/lib/SearchTypeResult/SearchFieldHeader.js +5 -5
  63. package/lib/SearchTypeResult/SearchHeader.d.ts +3 -3
  64. package/lib/SearchTypeResult/SearchHeader.js +9 -9
  65. package/lib/SearchTypeResult/SearchItem.d.ts +2 -3
  66. package/lib/SearchTypeResult/SearchItem.js +19 -19
  67. package/lib/SearchTypeResult/SearchNotionItem.d.ts +1 -1
  68. package/lib/SearchTypeResult/SearchNotionItem.js +12 -12
  69. package/lib/SearchTypeResult/SearchNotionsResult.js +8 -13
  70. package/lib/SearchTypeResult/index.d.ts +1 -0
  71. package/lib/Spinner/Spinner.d.ts +3 -3
  72. package/lib/Spinner/Spinner.js +2 -2
  73. package/lib/index.d.ts +2 -1
  74. package/lib/index.js +23 -0
  75. package/lib/locale/messages-en.d.ts +10 -0
  76. package/lib/locale/messages-en.js +10 -0
  77. package/lib/locale/messages-nb.d.ts +10 -0
  78. package/lib/locale/messages-nb.js +10 -0
  79. package/lib/locale/messages-nn.d.ts +10 -0
  80. package/lib/locale/messages-nn.js +10 -0
  81. package/package.json +10 -10
  82. package/src/Article/Article.tsx +17 -0
  83. package/src/Article/ArticleNotions.tsx +10 -7
  84. package/src/Breadcrumb/Breadcrumb.tsx +1 -1
  85. package/src/Breadcrumblist/Breadcrumblist.tsx +5 -3
  86. package/src/CloseButton/CloseButton.tsx +40 -0
  87. package/src/CloseButton/index.ts +11 -0
  88. package/src/Frontpage/FrontpageAllSubjects.tsx +2 -2
  89. package/src/Frontpage/FrontpageProgramMenu.tsx +1 -0
  90. package/src/MediaList/MediaList.tsx +158 -0
  91. package/src/MediaList/{index.js → index.ts} +0 -0
  92. package/src/MessageBox/MessageBox.tsx +117 -96
  93. package/src/MessageBox/MessageBoxTag.tsx +35 -0
  94. package/src/MessageBox/index.ts +3 -1
  95. package/src/NDLAFilm/FilmSlideshow.tsx +265 -0
  96. package/src/NDLAFilm/NavigationArrow.tsx +42 -0
  97. package/src/NDLAFilm/SlideshowIndicator.tsx +40 -0
  98. package/src/NDLAFilm/interfaces.ts +10 -0
  99. package/src/NDLAFilm/{shapes.js → shapes.ts} +0 -0
  100. package/src/Programme/Programme.tsx +7 -3
  101. package/src/SearchTypeResult/SearchFieldHeader.tsx +3 -3
  102. package/src/SearchTypeResult/SearchHeader.tsx +3 -3
  103. package/src/SearchTypeResult/SearchItem.tsx +4 -5
  104. package/src/SearchTypeResult/SearchNotionItem.tsx +1 -2
  105. package/src/SearchTypeResult/SearchNotionsResult.tsx +3 -8
  106. package/src/SearchTypeResult/index.ts +2 -0
  107. package/src/Spinner/Spinner.tsx +9 -5
  108. package/src/index.ts +2 -1
  109. package/src/locale/messages-en.ts +14 -0
  110. package/src/locale/messages-nb.ts +14 -0
  111. package/src/locale/messages-nn.ts +14 -0
  112. package/src/MediaList/MediaList.jsx +0 -182
  113. package/src/NDLAFilm/FilmSlideshow.jsx +0 -277
  114. package/src/NDLAFilm/NavigationArrow.jsx +0 -46
  115. package/src/NDLAFilm/SlideshowIndicator.jsx +0 -43
@@ -27,6 +27,7 @@ import { School as SchoolIcon, MenuBook as MenuBookIcon, Bookmark as BookmarkIco
27
27
  } from '@ndla/icons/action';
28
28
  import SafeLink from '@ndla/safelink';
29
29
  import { useTranslation } from 'react-i18next';
30
+ import MessageBoxTag from '../MessageBox/MessageBoxTag';
30
31
  import { jsx as ___EmotionJSX } from "@emotion/core";
31
32
 
32
33
  var Wrapper = _styled("div", {
@@ -37,7 +38,7 @@ var Wrapper = _styled("div", {
37
38
  }, " ", mq.range({
38
39
  from: breakpoints.wide
39
40
  }), "{display:flex;margin:32px 0;width:240px;position:fixed;left:22px;top:85px;", function (props) {
40
- return props.startOffset && "\n position: absolute;\n top: calc(".concat(props.startOffset, "px + 85px); \n ");
41
+ return props.startOffset && "\n top: calc(".concat(props.startOffset, "px + 85px); \n ");
41
42
  }, "}", mq.range({
42
43
  from: breakpoints.wide
43
44
  }), "{", function (props) {
@@ -50,14 +51,14 @@ var Wrapper = _styled("div", {
50
51
  from: '1440px'
51
52
  }), "{margin-left:52px;left:calc((100vw - 1480px) / 2);", function (props) {
52
53
  return props.leftAlign && "\n left: 0;\n ";
53
- }, "}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAkCwC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
54
+ }, "}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAkCwC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
54
55
 
55
56
  var Heading = _styled("div", {
56
57
  target: "eblhk4x1",
57
58
  label: "Heading"
58
- })("font-weight:bold;font-size:12px;line-height:15px;text-transform:uppercase;padding:0 0 18px 10px;", function (props) {
59
+ })("font-weight:bold;font-size:12px;line-height:15px;text-transform:uppercase;padding:0 0 10px 10px;", function (props) {
59
60
  return props.invertedStyle && "\n color: #fff;\n ";
60
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAoFyC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */");
61
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAmFyC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */");
61
62
 
62
63
  var List = _styled("ul", {
63
64
  target: "eblhk4x2",
@@ -68,7 +69,7 @@ var List = _styled("ul", {
68
69
  } : {
69
70
  name: "ibs9pp",
70
71
  styles: "margin:0 0 20px;padding:0;list-style:none;width:100%;",
71
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAiGsB","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */",
72
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAgGsB","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */",
72
73
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
73
74
  });
74
75
 
@@ -79,7 +80,7 @@ var ListItem = _styled("li", {
79
80
  return props.invertedStyle && "\n color: white;\n ";
80
81
  }, " &:hover{text-decoration:underline;color:", colors.brand.primary, ";", function (props) {
81
82
  return props.invertedStyle && "\n color: #fff;\n ";
82
- }, "}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAwGyC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
83
+ }, "}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAuGyC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
83
84
 
84
85
  var IconWrapper = _styled("span", {
85
86
  target: "eblhk4x4",
@@ -88,14 +89,14 @@ var IconWrapper = _styled("span", {
88
89
  return props.isCurrent && "\n color: ".concat(colors.brand.primary, ";\n ");
89
90
  }, " ", function (props) {
90
91
  return props.invertedStyle && "\n color: #fff;\n ";
91
- }, " .crumbicon{width:24px;height:24px;margin-top:-4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AA8I0C","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
92
+ }, " .crumbicon{width:24px;height:24px;margin-top:-4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AA6I0C","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */"));
92
93
 
93
94
  var Dot = _styled("span", {
94
95
  target: "eblhk4x5",
95
96
  label: "Dot"
96
97
  })("height:10px;width:10px;background-color:#20588f;border-radius:50%;display:inline-block;margin-left:-15px;margin-right:5px;", function (props) {
97
98
  return props.invertedStyle && "\n background-color: #fff;\n ";
98
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAqKsC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\n\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        position: absolute;\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 18px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */");
99
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAoKsC","file":"Breadcrumblist.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, { useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { mq, breakpoints, colors } from '@ndla/core';\nimport {\n  School as SchoolIcon,\n  MenuBook as MenuBookIcon,\n  Bookmark as BookmarkIcon,\n  Class as ClassIcon,\n  Home as HomeIcon,\n  // @ts-ignore\n} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n};\n\ntype InvertItProps = {\n  invertedStyle?: boolean;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: flex-start;\n  justify-content: flex-start;\n  flex-direction: column;\n  margin: 32px 0 16px;\n  width: auto;\n  z-index: 1;\n  ${(props) => props.hideOnNarrow && `display:none;`}\n  ${mq.range({ from: breakpoints.wide })} {\n    display: flex;\n    margin: 32px 0;\n    width: 240px;\n    position: fixed;\n    left: 22px;\n    top: 85px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + 85px); \n    `}\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    ${(props) =>\n      !props.isVisible &&\n      `\n    opacity: 0;\n    transition: opacity 125ms ease-in-out;\n  `}\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    margin: 32px 0;\n    left: 52px;\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n  ${mq.range({ from: '1440px' })} {\n    margin-left: 52px;\n    left: calc((100vw - 1480px) / 2);\n    ${(props) =>\n      props.leftAlign &&\n      `\n        left: 0;\n    `}\n  }\n`;\nconst Heading = styled.div<InvertItProps>`\n  font-weight: bold;\n  font-size: 12px;\n  line-height: 15px;\n  text-transform: uppercase;\n  padding: 0 0 10px 10px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n`;\n\nconst List = styled.ul`\n  margin: 0 0 20px;\n  padding: 0;\n  list-style: none;\n  width: 100%;\n`;\n\nconst ListItem = styled.li<InvertItProps>`\n  font-size: 16px;\n  position: relative;\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  margin-bottom: 8px;\n  a {\n    color: ${colors.brand.primary};\n    text-decoration: none;\n    box-shadow: none;\n    display: inline-block;\n    width: 99%;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    ${(props) =>\n      props.invertedStyle &&\n      `\n        color: white;\n    `}\n    &:hover {\n      text-decoration: underline;\n      color: ${colors.brand.primary};\n      ${(props) =>\n        props.invertedStyle &&\n        `\n          color: #fff;\n      `}\n    }\n  }\n`;\n\ntype IconProps = {\n  isCurrent: boolean;\n  invertedStyle?: boolean;\n};\n\nconst IconWrapper = styled.span<IconProps>`\n  margin: 0 8px;\n  color: ${colors.brand.tertiary};\n  display: inline-block;\n  min-width: 24px;\n  text-align: center;\n  ${(props) =>\n    props.isCurrent &&\n    `\n    color: ${colors.brand.primary};\n  `}\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      color: #fff;\n  `}\n  .crumbicon {\n    width: 24px;\n    height: 24px;\n    margin-top: -4px;\n  }\n`;\n\nconst Dot = styled.span<InvertItProps>`\n  height: 10px;\n  width: 10px;\n  background-color: #20588f;\n  border-radius: 50%;\n  display: inline-block;\n  margin-left: -15px;\n  margin-right: 5px;\n  ${(props) =>\n    props.invertedStyle &&\n    `\n      background-color: #fff;\n  `}\n`;\n\nconst TypeIcon = (type: string) => {\n  switch (type) {\n    case 'Subjecttype':\n      return <SchoolIcon className=\"crumbicon\" />;\n    case 'Subject':\n      return <MenuBookIcon className=\"crumbicon\" />;\n    case 'Topic':\n      return <BookmarkIcon className=\"crumbicon\" />;\n    case 'Subtopic':\n    case 'SubSubtopic':\n      return <ClassIcon className=\"crumbicon\" />;\n    case 'Home':\n      return <HomeIcon className=\"crumbicon\" />;\n    default:\n      return null;\n  }\n};\n\nexport type BreadcrumbItemProps = {\n  id: string | number;\n  label: string;\n  url: string;\n  typename?: 'Subjecttype' | 'Subject' | 'Topic' | 'Subtopic' | 'SubSubtopic' | 'Home';\n  isCurrent?: boolean | false;\n  icon?: React.ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: React.ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: React.MouseEvent<HTMLElement>, item: BreadcrumbItemProps) => void;\n  messageBoxTagMessage?: string;\n};\n\nconst Breadcrumblist = ({\n  children,\n  items,\n  startOffset = 0,\n  isVisible = true,\n  invertedStyle,\n  leftAlign,\n  hideOnNarrow,\n  onNav,\n  messageBoxTagMessage,\n}: BreadCrumbProps) => {\n  const { t } = useTranslation();\n  const [wrapperOffset, setWrapperOffset] = useState(startOffset);\n  const [useScrollEvent, setUseScrollEvent] = useState(false);\n\n  useEffect(() => {\n    const handleScroll = () => {\n      let position = 0;\n      if (window.pageYOffset < startOffset) {\n        position = startOffset;\n      }\n      setWrapperOffset(position);\n    };\n\n    if (useScrollEvent) {\n      window.addEventListener('scroll', handleScroll, { passive: true });\n    } else {\n      window.removeEventListener('scroll', handleScroll);\n    }\n\n    return () => {\n      window.removeEventListener('scroll', handleScroll);\n    };\n  }, [useScrollEvent, startOffset]);\n\n  const checkScreenSize = () => {\n    if (window.innerWidth >= 1301) {\n      // Wide. If larger, and there is a startOffset, the breadcrumb is positioned absolute at start\n      setUseScrollEvent(true);\n    } else {\n      setUseScrollEvent(false);\n    }\n  };\n\n  useEffect(() => {\n    checkScreenSize();\n    window.addEventListener('resize', checkScreenSize);\n\n    return () => {\n      window.removeEventListener('resize', checkScreenSize);\n    };\n  }, []);\n\n  return (\n    <>\n      <Wrapper leftAlign={leftAlign} startOffset={wrapperOffset} hideOnNarrow={hideOnNarrow} isVisible={isVisible}>\n        {items.length > 0 && (\n          <>\n            <Heading invertedStyle={invertedStyle}>{t('breadcrumb.youAreHere')}</Heading>\n            {messageBoxTagMessage && <MessageBoxTag tagMessage={messageBoxTagMessage} />}\n            <List data-testid=\"breadcrumb-list\">\n              {items.map((item: BreadcrumbItemProps) => {\n                const { id, label, url, typename, icon, isCurrent = false } = item;\n                return (\n                  <ListItem invertedStyle={invertedStyle} key={`${id}-${typename}`}>\n                    {isCurrent && <Dot invertedStyle={invertedStyle} />}\n                    <SafeLink\n                      className=\"linkitem\"\n                      to={url}\n                      onClick={(e: React.MouseEvent<HTMLElement>) => {\n                        onNav && onNav(e, item);\n                      }}\n                      aria-label={label}>\n                      <IconWrapper invertedStyle={invertedStyle} isCurrent={isCurrent}>\n                        {icon && icon}\n                        {typename && TypeIcon(typename)}\n                      </IconWrapper>\n                      <span>{label}</span>\n                    </SafeLink>\n                  </ListItem>\n                );\n              })}\n            </List>\n          </>\n        )}\n        {children}\n      </Wrapper>\n    </>\n  );\n};\n\nexport default Breadcrumblist;\n"]} */");
99
100
 
100
101
  var TypeIcon = function TypeIcon(type) {
101
102
  switch (type) {
@@ -140,7 +141,8 @@ var Breadcrumblist = function Breadcrumblist(_ref) {
140
141
  invertedStyle = _ref.invertedStyle,
141
142
  leftAlign = _ref.leftAlign,
142
143
  hideOnNarrow = _ref.hideOnNarrow,
143
- onNav = _ref.onNav;
144
+ onNav = _ref.onNav,
145
+ messageBoxTagMessage = _ref.messageBoxTagMessage;
144
146
 
145
147
  var _useTranslation = useTranslation(),
146
148
  t = _useTranslation.t;
@@ -202,7 +204,9 @@ var Breadcrumblist = function Breadcrumblist(_ref) {
202
204
  isVisible: isVisible
203
205
  }, items.length > 0 && ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Heading, {
204
206
  invertedStyle: invertedStyle
205
- }, t('breadcrumb.youAreHere')), ___EmotionJSX(List, {
207
+ }, t('breadcrumb.youAreHere')), messageBoxTagMessage && ___EmotionJSX(MessageBoxTag, {
208
+ tagMessage: messageBoxTagMessage
209
+ }), ___EmotionJSX(List, {
206
210
  "data-testid": "breadcrumb-list"
207
211
  }, items.map(function (item) {
208
212
  var id = item.id,
@@ -0,0 +1,62 @@
1
+ import _styled from "@emotion/styled-base";
2
+
3
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4
+
5
+ /**
6
+ * Copyright (c) 2022-present, NDLA.
7
+ *
8
+ * This source code is licensed under the GPLv3 license found in the
9
+ * LICENSE file in the root directory of this source tree.
10
+ *
11
+ */
12
+ import React from 'react';
13
+ import { Cross } from '@ndla/icons/action';
14
+ import { useTranslation } from 'react-i18next';
15
+ import { jsx as ___EmotionJSX } from "@emotion/core";
16
+
17
+ var CloseButtonWrapper = _styled("div", {
18
+ target: "e4bzt4x0",
19
+ label: "CloseButtonWrapper"
20
+ })(process.env.NODE_ENV === "production" ? {
21
+ name: "17bjy66",
22
+ styles: "position:relative;top:1px;right:1px;"
23
+ } : {
24
+ name: "17bjy66",
25
+ styles: "position:relative;top:1px;right:1px;",
26
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNsb3NlQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXcUMiLCJmaWxlIjoiQ2xvc2VCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENyb3NzIH0gZnJvbSAnQG5kbGEvaWNvbnMvYWN0aW9uJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5jb25zdCBDbG9zZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHRvcDogMXB4O1xuICByaWdodDogMXB4O1xuYDtcblxuY29uc3QgQ2xvc2VCdXQgPSBzdHlsZWQuYnV0dG9uYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgYm9yZGVyOiBub25lO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgY29sb3I6IHN0cmluZztcbn07XG5cbmV4cG9ydCBjb25zdCBDbG9zZUJ1dHRvbiA9ICh7IG9uQ2xpY2ssIGNvbG9yIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8Q2xvc2VCdXR0b25XcmFwcGVyIGFyaWEtbGFiZWw9e3QoJ2x1a2snKX0+XG4gICAgICA8Q2xvc2VCdXQgb25DbGljaz17b25DbGlja30+XG4gICAgICAgIDxDcm9zcyBzdHlsZT17eyB3aWR0aDogJzI0cHgnLCBoZWlnaHQ6ICcyNHB4JywgY29sb3I6IGNvbG9yIH19IC8+XG4gICAgICA8L0Nsb3NlQnV0PlxuICAgIDwvQ2xvc2VCdXR0b25XcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ2xvc2VCdXR0b247XG4iXX0= */",
27
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
28
+ });
29
+
30
+ var CloseBut = _styled("button", {
31
+ target: "e4bzt4x1",
32
+ label: "CloseBut"
33
+ })(process.env.NODE_ENV === "production" ? {
34
+ name: "1euagpl",
35
+ styles: "background-color:transparent;border:none;display:flex;"
36
+ } : {
37
+ name: "1euagpl",
38
+ styles: "background-color:transparent;border:none;display:flex;",
39
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNsb3NlQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQjhCIiwiZmlsZSI6IkNsb3NlQnV0dG9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBDcm9zcyB9IGZyb20gJ0BuZGxhL2ljb25zL2FjdGlvbic7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB0b3A6IDFweDtcbiAgcmlnaHQ6IDFweDtcbmA7XG5cbmNvbnN0IENsb3NlQnV0ID0gc3R5bGVkLmJ1dHRvbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogbm9uZTtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNvbG9yOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgY29uc3QgQ2xvc2VCdXR0b24gPSAoeyBvbkNsaWNrLCBjb2xvciB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPENsb3NlQnV0dG9uV3JhcHBlciBhcmlhLWxhYmVsPXt0KCdsdWtrJyl9PlxuICAgICAgPENsb3NlQnV0IG9uQ2xpY2s9e29uQ2xpY2t9PlxuICAgICAgICA8Q3Jvc3Mgc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcsIGNvbG9yOiBjb2xvciB9fSAvPlxuICAgICAgPC9DbG9zZUJ1dD5cbiAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENsb3NlQnV0dG9uO1xuIl19 */",
40
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
41
+ });
42
+
43
+ export var CloseButton = function CloseButton(_ref) {
44
+ var onClick = _ref.onClick,
45
+ color = _ref.color;
46
+
47
+ var _useTranslation = useTranslation(),
48
+ t = _useTranslation.t;
49
+
50
+ return ___EmotionJSX(CloseButtonWrapper, {
51
+ "aria-label": t('lukk')
52
+ }, ___EmotionJSX(CloseBut, {
53
+ onClick: onClick
54
+ }, ___EmotionJSX(Cross, {
55
+ style: {
56
+ width: '24px',
57
+ height: '24px',
58
+ color: color
59
+ }
60
+ })));
61
+ };
62
+ export default CloseButton;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Copyright (c) 2019-present, NDLA.
3
+ *
4
+ * This source code is licensed under the GPLv3 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+ import CloseButton from './CloseButton';
9
+ export { CloseButton };