@ndla/ui 5.0.0 → 6.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Breadcrumblist/Breadcrumblist.js +16 -9
- package/es/ContentPlaceholder/ContentPlaceholder.js +51 -0
- package/es/ContentPlaceholder/index.js +9 -0
- package/es/FactBox/FactBox.js +14 -31
- package/es/Frontpage/FrontpageSearch.js +10 -3
- package/es/Masthead/Masthead.js +9 -8
- package/es/Masthead/index.js +2 -1
- package/es/Masthead/utils.js +46 -0
- package/es/MessageBox/MessageBox.js +13 -7
- package/es/Notion/FigureNotion.js +3 -1
- package/es/Search/ContentTypeResult.js +4 -2
- package/es/Search/SearchField.js +5 -4
- package/es/Search/SearchResultSleeve.js +12 -10
- package/es/SearchTypeResult/SearchItem.js +8 -8
- package/es/all.css +1 -1
- package/es/index.js +2 -1
- package/lib/Breadcrumblist/Breadcrumblist.js +17 -9
- package/lib/ContentPlaceholder/ContentPlaceholder.d.ts +9 -0
- package/lib/ContentPlaceholder/ContentPlaceholder.js +54 -0
- package/lib/ContentPlaceholder/index.d.ts +9 -0
- package/lib/ContentPlaceholder/index.js +20 -0
- package/lib/FactBox/FactBox.js +14 -37
- package/lib/Frontpage/FrontpageSearch.js +10 -3
- package/lib/Masthead/Masthead.d.ts +3 -3
- package/lib/Masthead/Masthead.js +10 -8
- package/lib/Masthead/index.d.ts +2 -1
- package/lib/Masthead/index.js +14 -0
- package/lib/Masthead/utils.d.ts +11 -0
- package/lib/Masthead/utils.js +53 -0
- package/lib/MessageBox/MessageBox.d.ts +2 -1
- package/lib/MessageBox/MessageBox.js +13 -7
- package/lib/Notion/FigureNotion.js +3 -1
- package/lib/Search/ContentTypeResult.js +4 -2
- package/lib/Search/SearchField.js +5 -4
- package/lib/Search/SearchResultSleeve.js +12 -10
- package/lib/SearchTypeResult/SearchItem.js +8 -8
- package/lib/all.css +1 -1
- package/lib/index.d.ts +2 -1
- package/lib/index.js +23 -0
- package/package.json +13 -13
- package/src/Breadcrumblist/Breadcrumblist.tsx +12 -3
- package/src/ContentPlaceholder/ContentPlaceholder.tsx +68 -0
- package/src/ContentPlaceholder/index.ts +11 -0
- package/src/FactBox/FactBox.tsx +8 -10
- package/src/FactBox/component.factbox.scss +12 -0
- package/src/Frontpage/FrontpageSearch.tsx +7 -0
- package/src/Masthead/Masthead.tsx +7 -6
- package/src/Masthead/component.masthead.scss +3 -62
- package/src/Masthead/index.ts +3 -1
- package/src/Masthead/utils.ts +33 -0
- package/src/MessageBox/MessageBox.tsx +5 -1
- package/src/Notion/FigureNotion.tsx +25 -23
- package/src/Search/ContentTypeResult.tsx +3 -1
- package/src/Search/SearchField.jsx +2 -1
- package/src/Search/SearchResultSleeve.tsx +8 -2
- package/src/SearchTypeResult/SearchItem.tsx +0 -1
- package/src/index.ts +2 -1
|
@@ -27,6 +27,7 @@ import { School as SchoolIcon, MenuBook as MenuBookIcon, Bookmark as BookmarkIco
|
|
|
27
27
|
import SafeLink from '@ndla/safelink';
|
|
28
28
|
import { useTranslation } from 'react-i18next';
|
|
29
29
|
import MessageBoxTag from '../MessageBox/MessageBoxTag';
|
|
30
|
+
import { useMastheadHeight } from '../Masthead';
|
|
30
31
|
import { jsx as ___EmotionJSX } from "@emotion/core";
|
|
31
32
|
|
|
32
33
|
var Wrapper = _styled("div", {
|
|
@@ -36,8 +37,10 @@ var Wrapper = _styled("div", {
|
|
|
36
37
|
return props.hideOnNarrow && "display:none;";
|
|
37
38
|
}, " ", mq.range({
|
|
38
39
|
from: breakpoints.wide
|
|
39
|
-
}), "{display:flex;margin:32px 0;width:240px;position:fixed;left:22px;top:
|
|
40
|
-
return props.
|
|
40
|
+
}), "{display:flex;margin:32px 0;width:240px;position:fixed;left:22px;top:", function (props) {
|
|
41
|
+
return props.mastheadHeight || 85;
|
|
42
|
+
}, "px;", function (props) {
|
|
43
|
+
return props.startOffset && "\n top: calc(".concat(props.startOffset, "px + ").concat(props.mastheadHeight || 85, "px); \n ");
|
|
41
44
|
}, "}", mq.range({
|
|
42
45
|
from: breakpoints.wide
|
|
43
46
|
}), "{", function (props) {
|
|
@@ -50,14 +53,14 @@ var Wrapper = _styled("div", {
|
|
|
50
53
|
from: '1440px'
|
|
51
54
|
}), "{margin-left:52px;left:calc((100vw - 1480px) / 2);", function (props) {
|
|
52
55
|
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":"AAiCwC","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */"));
|
|
56
|
+
}, "}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Breadcrumblist.tsx"],"names":[],"mappings":"AAmCwC","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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
57
|
|
|
55
58
|
var Heading = _styled("div", {
|
|
56
59
|
target: "eblhk4x1",
|
|
57
60
|
label: "Heading"
|
|
58
61
|
})("font-weight:bold;font-size:12px;line-height:15px;text-transform:uppercase;padding:0 0 10px 10px;", function (props) {
|
|
59
62
|
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":"AAkFyC","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */");
|
|
63
|
+
}, 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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
64
|
|
|
62
65
|
var List = _styled("ul", {
|
|
63
66
|
target: "eblhk4x2",
|
|
@@ -68,7 +71,7 @@ var List = _styled("ul", {
|
|
|
68
71
|
} : {
|
|
69
72
|
name: "ibs9pp",
|
|
70
73
|
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":"AA+FsB","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */",
|
|
74
|
+
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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
75
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
73
76
|
});
|
|
74
77
|
|
|
@@ -79,7 +82,7 @@ var ListItem = _styled("li", {
|
|
|
79
82
|
return props.invertedStyle && "\n color: white;\n ";
|
|
80
83
|
}, " &:hover{text-decoration:underline;color:", colors.brand.primary, ";", function (props) {
|
|
81
84
|
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":"AAsGyC","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */"));
|
|
85
|
+
}, "}}" + (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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
86
|
|
|
84
87
|
var IconWrapper = _styled("span", {
|
|
85
88
|
target: "eblhk4x4",
|
|
@@ -88,14 +91,14 @@ var IconWrapper = _styled("span", {
|
|
|
88
91
|
return props.isCurrent && "\n color: ".concat(colors.brand.primary, ";\n ");
|
|
89
92
|
}, " ", function (props) {
|
|
90
93
|
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":"AA4I0C","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */"));
|
|
94
|
+
}, " .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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
95
|
|
|
93
96
|
var Dot = _styled("span", {
|
|
94
97
|
target: "eblhk4x5",
|
|
95
98
|
label: "Dot"
|
|
96
99
|
})("height:10px;width:10px;background-color:#20588f;border-radius:50%;display:inline-block;margin-left:-15px;margin-right:5px;", function (props) {
|
|
97
100
|
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":"AAmKsC","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, { ReactNode, useEffect, useState, MouseEvent } 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} 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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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: 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"]} */");
|
|
101
|
+
}, 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, { ReactNode, useEffect, useState, MouseEvent } 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} from '@ndla/icons/action';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport MessageBoxTag from '../MessageBox/MessageBoxTag';\nimport { useMastheadHeight } from '../Masthead';\n\ntype WrapperProps = {\n  startOffset?: number;\n  isVisible?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  mastheadHeight?: number;\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: ${(props) => props.mastheadHeight || 85}px;\n    ${(props) =>\n      props.startOffset &&\n      `\n        top: calc(${props.startOffset}px + ${props.mastheadHeight || 85}px); \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?: ReactNode;\n};\n\ntype BreadCrumbProps = {\n  children?: ReactNode;\n  items: BreadcrumbItemProps[];\n  startOffset?: number;\n  isVisible?: boolean;\n  invertedStyle?: boolean;\n  leftAlign?: boolean;\n  hideOnNarrow?: boolean;\n  onNav?: (e: 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  const { height: mastheadHeight } = useMastheadHeight();\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\n        leftAlign={leftAlign}\n        startOffset={wrapperOffset}\n        hideOnNarrow={hideOnNarrow}\n        isVisible={isVisible}\n        mastheadHeight={mastheadHeight}>\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: 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
102
|
|
|
100
103
|
var TypeIcon = function TypeIcon(type) {
|
|
101
104
|
switch (type) {
|
|
@@ -156,6 +159,9 @@ var Breadcrumblist = function Breadcrumblist(_ref) {
|
|
|
156
159
|
useScrollEvent = _useState4[0],
|
|
157
160
|
setUseScrollEvent = _useState4[1];
|
|
158
161
|
|
|
162
|
+
var _useMastheadHeight = useMastheadHeight(),
|
|
163
|
+
mastheadHeight = _useMastheadHeight.height;
|
|
164
|
+
|
|
159
165
|
useEffect(function () {
|
|
160
166
|
var handleScroll = function handleScroll() {
|
|
161
167
|
var position = 0;
|
|
@@ -200,7 +206,8 @@ var Breadcrumblist = function Breadcrumblist(_ref) {
|
|
|
200
206
|
leftAlign: leftAlign,
|
|
201
207
|
startOffset: wrapperOffset,
|
|
202
208
|
hideOnNarrow: hideOnNarrow,
|
|
203
|
-
isVisible: isVisible
|
|
209
|
+
isVisible: isVisible,
|
|
210
|
+
mastheadHeight: mastheadHeight
|
|
204
211
|
}, items.length > 0 && ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Heading, {
|
|
205
212
|
invertedStyle: invertedStyle
|
|
206
213
|
}, t('breadcrumb.youAreHere')), messageBoxTagMessage && ___EmotionJSX(MessageBoxTag, {
|
|
@@ -0,0 +1,51 @@
|
|
|
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 { colors } from '@ndla/core';
|
|
14
|
+
import { jsx as ___EmotionJSX } from "@emotion/core";
|
|
15
|
+
|
|
16
|
+
var Wrapper = _styled("div", {
|
|
17
|
+
target: "e1mxrs7b0",
|
|
18
|
+
label: "Wrapper"
|
|
19
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
20
|
+
name: "1mmorre",
|
|
21
|
+
styles: "position:fixed;z-index:98;top:0;left:0;right:0;"
|
|
22
|
+
} : {
|
|
23
|
+
name: "1mmorre",
|
|
24
|
+
styles: "position:fixed;z-index:98;top:0;left:0;right:0;",
|
|
25
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentPlaceholder.tsx"],"names":[],"mappings":"AAY0B","file":"ContentPlaceholder.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport { colors } from '@ndla/core';\n\nconst Wrapper = styled.div`\n  position: fixed;\n  z-index: 98;\n  top: 0;\n  left: 0;\n  right: 0;\n`;\n\nconst Background = styled.div`\n  height: 100vh;\n  width: 100vw;\n  background-color: ${colors.brand.greyLightest};\n`;\n\nconst Placeholder = styled.div`\n  position: absolute;\n  display: block;\n  height: 100vh;\n  width: 100vw;\n  margin-top: 86px;\n  background-position-x: center;\n  background-position-y: 65px;\n  background-repeat: no-repeat;\n  animation-name: pulseAnimation;\n  animation-duration: 1.6s;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  @media (max-width: 476px) {\n    background-size: 280px 609px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyODBweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDI4MCA2MDkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJ0aW55IiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjEiIHdpZHRoPSIxNjQuMzA1NTU2IiBoZWlnaHQ9IjMyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9IjQwLjgzMzMzMzMiIGhlaWdodD0iMTYiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxODAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjcwIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iNzAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjUiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5OCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjQ4MCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUwOCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUzNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU2MyIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU5MSIgd2lkdGg9IjE5Mi41IiBoZWlnaHQ9IjE4Ij48L3JlY3Q+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+);\n  }\n  @media (min-width: 476px) {\n    background-size: 375px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIzNzVweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDM3NSA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJzbWFsbCIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMjIwLjU4ODIzNSIgaGVpZ2h0PSI0MiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjAiIHdpZHRoPSI1NC4xNDQzODUiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxMTAuMjk0MTE4IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMjY0LjcwNTg4MiIgeT0iMjE1IiB3aWR0aD0iMTEwLjI5NDExOCIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjI1Ny42ODcxNjYiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 601px) {\n    background-position-y: 95px;\n    background-size: 530px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI1MzBweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDUzMCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLW1lZGl1bSIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMzExIiBoZWlnaHQ9IjQyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9Ijc3IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjE1IiB3aWR0aD0iMTU2IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMzc0IiB5PSIyMTUiIHdpZHRoPSIxNTYiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyOTAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzUxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iOTEiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxMjciIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxNjMiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI2ODAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3MTYiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3NTIiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3ODgiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI4MjQiIHdpZHRoPSIzNjMiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 768px) {\n    background-size: 624px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI2MjRweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDYyNCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLWxhcmdlIiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjciIHdpZHRoPSIzMjYiIGhlaWdodD0iNDIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIwIiB3aWR0aD0iODEiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxNjMiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSI0NjEiIHk9IjIxNSIgd2lkdGg9IjE2MyIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjM4MC42NCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgIDwvZz4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);\n  }\n`;\n\nconst ContentPlaceholder = () => {\n  return (\n    <Wrapper>\n      <Placeholder />\n      <Background />\n    </Wrapper>\n  );\n};\n\nexport default ContentPlaceholder;\n"]} */",
|
|
26
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
var Background = _styled("div", {
|
|
30
|
+
target: "e1mxrs7b1",
|
|
31
|
+
label: "Background"
|
|
32
|
+
})("height:100vh;width:100vw;background-color:", colors.brand.greyLightest, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentPlaceholder.tsx"],"names":[],"mappings":"AAoB6B","file":"ContentPlaceholder.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport { colors } from '@ndla/core';\n\nconst Wrapper = styled.div`\n  position: fixed;\n  z-index: 98;\n  top: 0;\n  left: 0;\n  right: 0;\n`;\n\nconst Background = styled.div`\n  height: 100vh;\n  width: 100vw;\n  background-color: ${colors.brand.greyLightest};\n`;\n\nconst Placeholder = styled.div`\n  position: absolute;\n  display: block;\n  height: 100vh;\n  width: 100vw;\n  margin-top: 86px;\n  background-position-x: center;\n  background-position-y: 65px;\n  background-repeat: no-repeat;\n  animation-name: pulseAnimation;\n  animation-duration: 1.6s;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  @media (max-width: 476px) {\n    background-size: 280px 609px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyODBweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDI4MCA2MDkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJ0aW55IiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjEiIHdpZHRoPSIxNjQuMzA1NTU2IiBoZWlnaHQ9IjMyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9IjQwLjgzMzMzMzMiIGhlaWdodD0iMTYiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxODAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjcwIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iNzAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjUiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5OCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjQ4MCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUwOCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUzNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU2MyIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU5MSIgd2lkdGg9IjE5Mi41IiBoZWlnaHQ9IjE4Ij48L3JlY3Q+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+);\n  }\n  @media (min-width: 476px) {\n    background-size: 375px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIzNzVweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDM3NSA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJzbWFsbCIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMjIwLjU4ODIzNSIgaGVpZ2h0PSI0MiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjAiIHdpZHRoPSI1NC4xNDQzODUiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxMTAuMjk0MTE4IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMjY0LjcwNTg4MiIgeT0iMjE1IiB3aWR0aD0iMTEwLjI5NDExOCIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjI1Ny42ODcxNjYiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 601px) {\n    background-position-y: 95px;\n    background-size: 530px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI1MzBweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDUzMCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLW1lZGl1bSIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMzExIiBoZWlnaHQ9IjQyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9Ijc3IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjE1IiB3aWR0aD0iMTU2IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMzc0IiB5PSIyMTUiIHdpZHRoPSIxNTYiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyOTAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzUxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iOTEiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxMjciIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxNjMiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI2ODAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3MTYiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3NTIiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3ODgiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI4MjQiIHdpZHRoPSIzNjMiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 768px) {\n    background-size: 624px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI2MjRweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDYyNCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLWxhcmdlIiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjciIHdpZHRoPSIzMjYiIGhlaWdodD0iNDIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIwIiB3aWR0aD0iODEiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxNjMiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSI0NjEiIHk9IjIxNSIgd2lkdGg9IjE2MyIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjM4MC42NCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgIDwvZz4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);\n  }\n`;\n\nconst ContentPlaceholder = () => {\n  return (\n    <Wrapper>\n      <Placeholder />\n      <Background />\n    </Wrapper>\n  );\n};\n\nexport default ContentPlaceholder;\n"]} */"));
|
|
33
|
+
|
|
34
|
+
var Placeholder = _styled("div", {
|
|
35
|
+
target: "e1mxrs7b2",
|
|
36
|
+
label: "Placeholder"
|
|
37
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
38
|
+
name: "1uxl3qw",
|
|
39
|
+
styles: "position:absolute;display:block;height:100vh;width:100vw;margin-top:86px;background-position-x:center;background-position-y:65px;background-repeat:no-repeat;animation-name:pulseAnimation;animation-duration:1.6s;animation-timing-function:ease-in-out;animation-iteration-count:infinite;@media (max-width:476px){background-size:280px 609px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyODBweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDI4MCA2MDkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJ0aW55IiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjEiIHdpZHRoPSIxNjQuMzA1NTU2IiBoZWlnaHQ9IjMyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9IjQwLjgzMzMzMzMiIGhlaWdodD0iMTYiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxODAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjcwIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iNzAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjUiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5OCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjQ4MCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUwOCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUzNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU2MyIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU5MSIgd2lkdGg9IjE5Mi41IiBoZWlnaHQ9IjE4Ij48L3JlY3Q+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+);}@media (min-width:476px){background-size:375px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIzNzVweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDM3NSA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJzbWFsbCIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMjIwLjU4ODIzNSIgaGVpZ2h0PSI0MiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjAiIHdpZHRoPSI1NC4xNDQzODUiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxMTAuMjk0MTE4IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMjY0LjcwNTg4MiIgeT0iMjE1IiB3aWR0aD0iMTEwLjI5NDExOCIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjI1Ny42ODcxNjYiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);}@media (min-width:601px){background-position-y:95px;background-size:530px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI1MzBweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDUzMCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLW1lZGl1bSIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMzExIiBoZWlnaHQ9IjQyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9Ijc3IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjE1IiB3aWR0aD0iMTU2IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMzc0IiB5PSIyMTUiIHdpZHRoPSIxNTYiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyOTAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzUxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iOTEiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxMjciIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxNjMiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI2ODAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3MTYiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3NTIiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3ODgiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI4MjQiIHdpZHRoPSIzNjMiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);}@media (min-width:768px){background-size:624px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI2MjRweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDYyNCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLWxhcmdlIiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjciIHdpZHRoPSIzMjYiIGhlaWdodD0iNDIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIwIiB3aWR0aD0iODEiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxNjMiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSI0NjEiIHk9IjIxNSIgd2lkdGg9IjE2MyIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjM4MC42NCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgIDwvZz4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);}"
|
|
40
|
+
} : {
|
|
41
|
+
name: "1uxl3qw",
|
|
42
|
+
styles: "position:absolute;display:block;height:100vh;width:100vw;margin-top:86px;background-position-x:center;background-position-y:65px;background-repeat:no-repeat;animation-name:pulseAnimation;animation-duration:1.6s;animation-timing-function:ease-in-out;animation-iteration-count:infinite;@media (max-width:476px){background-size:280px 609px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyODBweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDI4MCA2MDkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJ0aW55IiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjEiIHdpZHRoPSIxNjQuMzA1NTU2IiBoZWlnaHQ9IjMyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9IjQwLjgzMzMzMzMiIGhlaWdodD0iMTYiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxODAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjcwIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iNzAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjUiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5OCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjQ4MCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUwOCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUzNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU2MyIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU5MSIgd2lkdGg9IjE5Mi41IiBoZWlnaHQ9IjE4Ij48L3JlY3Q+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+);}@media (min-width:476px){background-size:375px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIzNzVweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDM3NSA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJzbWFsbCIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMjIwLjU4ODIzNSIgaGVpZ2h0PSI0MiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjAiIHdpZHRoPSI1NC4xNDQzODUiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxMTAuMjk0MTE4IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMjY0LjcwNTg4MiIgeT0iMjE1IiB3aWR0aD0iMTEwLjI5NDExOCIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjI1Ny42ODcxNjYiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);}@media (min-width:601px){background-position-y:95px;background-size:530px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI1MzBweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDUzMCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLW1lZGl1bSIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMzExIiBoZWlnaHQ9IjQyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9Ijc3IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjE1IiB3aWR0aD0iMTU2IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMzc0IiB5PSIyMTUiIHdpZHRoPSIxNTYiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyOTAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzUxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iOTEiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxMjciIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxNjMiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI2ODAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3MTYiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3NTIiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3ODgiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI4MjQiIHdpZHRoPSIzNjMiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);}@media (min-width:768px){background-size:624px 848px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI2MjRweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDYyNCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLWxhcmdlIiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjciIHdpZHRoPSIzMjYiIGhlaWdodD0iNDIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIwIiB3aWR0aD0iODEiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxNjMiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSI0NjEiIHk9IjIxNSIgd2lkdGg9IjE2MyIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjM4MC42NCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgIDwvZz4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);}",
|
|
43
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentPlaceholder.tsx"],"names":[],"mappings":"AA0B8B","file":"ContentPlaceholder.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport { colors } from '@ndla/core';\n\nconst Wrapper = styled.div`\n  position: fixed;\n  z-index: 98;\n  top: 0;\n  left: 0;\n  right: 0;\n`;\n\nconst Background = styled.div`\n  height: 100vh;\n  width: 100vw;\n  background-color: ${colors.brand.greyLightest};\n`;\n\nconst Placeholder = styled.div`\n  position: absolute;\n  display: block;\n  height: 100vh;\n  width: 100vw;\n  margin-top: 86px;\n  background-position-x: center;\n  background-position-y: 65px;\n  background-repeat: no-repeat;\n  animation-name: pulseAnimation;\n  animation-duration: 1.6s;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  @media (max-width: 476px) {\n    background-size: 280px 609px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyODBweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDI4MCA2MDkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJ0aW55IiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjEiIHdpZHRoPSIxNjQuMzA1NTU2IiBoZWlnaHQ9IjMyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9IjQwLjgzMzMzMzMiIGhlaWdodD0iMTYiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxODAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjcwIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iNzAiIHdpZHRoPSIyODAiIGhlaWdodD0iMjUiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5OCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIyNSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjQ4MCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUwOCIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjUzNSIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU2MyIgd2lkdGg9IjI4MCIgaGVpZ2h0PSIxOCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjU5MSIgd2lkdGg9IjE5Mi41IiBoZWlnaHQ9IjE4Ij48L3JlY3Q+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+);\n  }\n  @media (min-width: 476px) {\n    background-size: 375px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIzNzVweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDM3NSA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJzbWFsbCIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMjIwLjU4ODIzNSIgaGVpZ2h0PSI0MiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjAiIHdpZHRoPSI1NC4xNDQzODUiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxMTAuMjk0MTE4IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMjY0LjcwNTg4MiIgeT0iMjE1IiB3aWR0aD0iMTEwLjI5NDExOCIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjM3NSIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjI1Ny42ODcxNjYiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 601px) {\n    background-position-y: 95px;\n    background-size: 530px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI1MzBweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDUzMCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLW1lZGl1bSIgZmlsbD0iI0U2RTZFNiIgZmlsbC1ydWxlPSJub256ZXJvIj4gICAgICAgICAgICA8ZyBpZD0iR3JvdXAiPiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI3IiB3aWR0aD0iMzExIiBoZWlnaHQ9IjQyIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMCIgd2lkdGg9Ijc3IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjE1IiB3aWR0aD0iMTU2IiBoZWlnaHQ9IjIxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMzc0IiB5PSIyMTUiIHdpZHRoPSIxNTYiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyOTAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzUxIj48L3JlY3Q+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iOTEiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxMjciIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIxNjMiIHdpZHRoPSI1MzAiIGhlaWdodD0iMzIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI2ODAiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3MTYiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3NTIiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI3ODgiIHdpZHRoPSI1MzAiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI4MjQiIHdpZHRoPSIzNjMiIGhlaWdodD0iMjQiPjwvcmVjdD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);\n  }\n  @media (min-width: 768px) {\n    background-size: 624px 848px;\n    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSI2MjRweCIgaGVpZ2h0PSI4NDhweCIgdmlld0JveD0iMCAwIDYyNCA4NDgiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+ICAgICAgICA8dGl0bGU+R3JvdXA8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxnIGlkPSJhcnRpY2xlLWxhcmdlIiBmaWxsPSIjRTZFNkU2IiBmaWxsLXJ1bGU9Im5vbnplcm8iPiAgICAgICAgICAgIDxnIGlkPSJHcm91cCI+ICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUtMiIgeD0iMCIgeT0iMjciIHdpZHRoPSIzMjYiIGhlaWdodD0iNDIiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIwIiB3aWR0aD0iODEiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSIyMTUiIHdpZHRoPSIxNjMiIGhlaWdodD0iMjEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSI0NjEiIHk9IjIxNSIgd2lkdGg9IjE2MyIgaGVpZ2h0PSIyMSI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjI5MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzNTEiPjwvcmVjdD4gICAgICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS0yIiB4PSIwIiB5PSI5MSIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjEyNyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjE2MyIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIzMiI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjY4MCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjcxNiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc1MiIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9Ijc4OCIgd2lkdGg9IjYyNCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLTIiIHg9IjAiIHk9IjgyNCIgd2lkdGg9IjM4MC42NCIgaGVpZ2h0PSIyNCI+PC9yZWN0PiAgICAgICAgICAgIDwvZz4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);\n  }\n`;\n\nconst ContentPlaceholder = () => {\n  return (\n    <Wrapper>\n      <Placeholder />\n      <Background />\n    </Wrapper>\n  );\n};\n\nexport default ContentPlaceholder;\n"]} */",
|
|
44
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
var ContentPlaceholder = function ContentPlaceholder() {
|
|
48
|
+
return ___EmotionJSX(Wrapper, null, ___EmotionJSX(Placeholder, null), ___EmotionJSX(Background, null));
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export default ContentPlaceholder;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2022-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 ContentPlaceholder from './ContentPlaceholder';
|
|
9
|
+
export default ContentPlaceholder;
|