@ndla/ui 34.1.1 → 34.2.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/types.js CHANGED
@@ -6,5 +6,5 @@
6
6
  *
7
7
  */
8
8
 
9
- var locales = ['nb', 'nn', 'en', 'se'];
9
+ var locales = ['nb', 'nn', 'en', 'se', 'sma'];
10
10
  export {};
@@ -21,7 +21,7 @@ var EditorName = function EditorName(_ref) {
21
21
  return (0, _jsxRuntime.jsxs)("span", {
22
22
  children: [(0, _jsxRuntime.jsx)("strong", {
23
23
  children: title
24
- }), " ", name]
24
+ }), " ".concat(name)]
25
25
  });
26
26
  };
27
27
  exports.EditorName = EditorName;
@@ -24,7 +24,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "d
24
24
 
25
25
  var SIDE_NAV_WIDTH = '372px';
26
26
  var StyledMenuItem = /*#__PURE__*/(0, _base["default"])("li", {
27
- target: "eipwgxz3",
27
+ target: "eipwgxz4",
28
28
  label: "StyledMenuItem"
29
29
  })("margin:0;a{box-shadow:none;display:inline-flex;align-items:center;padding:", _core.spacing.small, ";>span{display:flex;align-items:center;", _core.fonts.sizes(14, 1.2), ";color:", _core.colors.brand.primary, ";", _core.mq.range({
30
30
  from: _core.breakpoints.tablet
@@ -47,11 +47,15 @@ var StyledMenuItem = /*#__PURE__*/(0, _base["default"])("li", {
47
47
  return !props.afterCurrent && !props.current && props.invertedStyle && "\n ".concat(_core.mq.range({
48
48
  from: _core.breakpoints.tablet
49
49
  }), " {\n a {\n > span {\n color: #fff;\n }\n color: #fff;\n }\n }\n ");
50
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA6BqD","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  const getContentTypeBadge = (type?: string) => {\n    if (!type) {\n      return <ContentTypeBadge type={constants.contentTypes.LEARNING_PATH} background size=\"small\" />;\n    }\n    return <ContentTypeBadge type={type} background size=\"small\" />;\n  };\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink onClick={onStepNavigate} to={toLearningPathUrl(learningPathId, id)}>\n              <StyledContentType>\n                {getContentTypeBadge(type)}\n                {hasRead(id, cookies) && (\n                  <ReadIcon>\n                    <LearningPathRead />\n                  </ReadIcon>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
50
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA6BqD","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
51
51
  var StyledContentType = /*#__PURE__*/(0, _base["default"])("div", {
52
- target: "eipwgxz2",
52
+ target: "eipwgxz3",
53
53
  label: "StyledContentType"
54
- })("position:relative;z-index:1;margin-right:", _core.spacingUnit * 0.75, "px;max-height:36px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAyIoC","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  const getContentTypeBadge = (type?: string) => {\n    if (!type) {\n      return <ContentTypeBadge type={constants.contentTypes.LEARNING_PATH} background size=\"small\" />;\n    }\n    return <ContentTypeBadge type={type} background size=\"small\" />;\n  };\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink onClick={onStepNavigate} to={toLearningPathUrl(learningPathId, id)}>\n              <StyledContentType>\n                {getContentTypeBadge(type)}\n                {hasRead(id, cookies) && (\n                  <ReadIcon>\n                    <LearningPathRead />\n                  </ReadIcon>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
54
+ })("position:relative;z-index:1;margin-right:", _core.spacingUnit * 0.75, "px;max-height:36px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAyIoC","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
55
+ var HiddenSpan = /*#__PURE__*/(0, _base["default"])("span", {
56
+ target: "eipwgxz2",
57
+ label: "HiddenSpan"
58
+ })(_core.utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAgJ8B","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
55
59
  var StyledNavigation = /*#__PURE__*/(0, _base["default"])("nav", {
56
60
  target: "eipwgxz1",
57
61
  label: "StyledNavigation"
@@ -61,12 +65,12 @@ var StyledNavigation = /*#__PURE__*/(0, _base["default"])("nav", {
61
65
  }), "{margin-left:-28px;}", _core.mq.range({
62
66
  from: _core.breakpoints.tablet,
63
67
  until: _core.breakpoints.desktop
64
- }), "{", StyledMenuItem, "{span{display:none;}&:first-of-type{&:after{display:none!important;}}a:hover,a:focus{position:relative;z-index:1;width:", SIDE_NAV_WIDTH, ";background:", _core.colors.brand.greyLighter, ";span{display:flex;}}}};label:StyledNavigation;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA8JO","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  const getContentTypeBadge = (type?: string) => {\n    if (!type) {\n      return <ContentTypeBadge type={constants.contentTypes.LEARNING_PATH} background size=\"small\" />;\n    }\n    return <ContentTypeBadge type={type} background size=\"small\" />;\n  };\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink onClick={onStepNavigate} to={toLearningPathUrl(learningPathId, id)}>\n              <StyledContentType>\n                {getContentTypeBadge(type)}\n                {hasRead(id, cookies) && (\n                  <ReadIcon>\n                    <LearningPathRead />\n                  </ReadIcon>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
65
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAqJ0D","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  const getContentTypeBadge = (type?: string) => {\n    if (!type) {\n      return <ContentTypeBadge type={constants.contentTypes.LEARNING_PATH} background size=\"small\" />;\n    }\n    return <ContentTypeBadge type={type} background size=\"small\" />;\n  };\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink onClick={onStepNavigate} to={toLearningPathUrl(learningPathId, id)}>\n              <StyledContentType>\n                {getContentTypeBadge(type)}\n                {hasRead(id, cookies) && (\n                  <ReadIcon>\n                    <LearningPathRead />\n                  </ReadIcon>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
68
+ }), "{", StyledMenuItem, "{span{display:none;}&:first-of-type{&:after{display:none!important;}}a:hover,a:focus{position:relative;z-index:1;width:", SIDE_NAV_WIDTH, ";background:", _core.colors.brand.greyLighter, ";span{display:flex;}}}};label:StyledNavigation;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAkKO","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
69
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AAyJ0D","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
66
70
  var ReadIcon = /*#__PURE__*/(0, _base["default"])("div", {
67
71
  target: "eipwgxz0",
68
72
  label: "ReadIcon"
69
- })("border-radius:100%;display:flex;align-items:center;justify-content:center;position:absolute;top:-6px;right:0;width:16px;height:16px;background:", _core.colors.brand.secondary, ";color:", _core.colors.text.light, ";transform:translateX(4px);svg{width:12px;height:12px;fill:", _core.colors.brand.lighter, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA2L2B","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  const getContentTypeBadge = (type?: string) => {\n    if (!type) {\n      return <ContentTypeBadge type={constants.contentTypes.LEARNING_PATH} background size=\"small\" />;\n    }\n    return <ContentTypeBadge type={type} background size=\"small\" />;\n  };\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink onClick={onStepNavigate} to={toLearningPathUrl(learningPathId, id)}>\n              <StyledContentType>\n                {getContentTypeBadge(type)}\n                {hasRead(id, cookies) && (\n                  <ReadIcon>\n                    <LearningPathRead />\n                  </ReadIcon>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
73
+ })("border-radius:100%;display:flex;align-items:center;justify-content:center;position:absolute;top:-6px;right:0;width:16px;height:16px;background:", _core.colors.brand.secondary, ";color:", _core.colors.text.light, ";transform:translateX(4px);svg{width:12px;height:12px;fill:", _core.colors.brand.lighter, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LearningPathMenuContent.tsx"],"names":[],"mappings":"AA+L2B","file":"LearningPathMenuContent.tsx","sourcesContent":["/**\n * Copyright (c) 2019-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 { css } from '@emotion/react';\nimport { colors, spacing, spacingUnit, fonts, mq, breakpoints, animations, utils } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { LearningPathRead } from '@ndla/icons/contentType';\nimport { StepProps } from './LearningPathMenu';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport constants from '../model';\n\nconst SIDE_NAV_WIDTH = '372px';\n\ntype StyledMenuItemProps = {\n  current?: boolean;\n  isOpen: boolean;\n  afterCurrent: boolean;\n  indexNumber: number;\n  hasRead?: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledMenuItem = styled.li<StyledMenuItemProps>`\n  margin: 0;\n  a {\n    box-shadow: none;\n    display: inline-flex;\n    align-items: center;\n    padding: ${spacing.small};\n    > span {\n      display: flex;\n      align-items: center;\n      ${fonts.sizes(14, 1.2)};\n      color: ${colors.brand.primary};\n      ${mq.range({ from: breakpoints.tablet })} {\n        color: ${({ invertedStyle }) => (invertedStyle ? '#fff' : colors.brand.primary)};\n        font-weight: ${fonts.weight.semibold};\n      }\n    }\n    &:hover,\n    &:focus {\n      > span {\n        text-decoration: underline;\n      }\n    }\n  }\n  ${mq.range({ until: breakpoints.desktop })} {\n    ${(props) =>\n      !props.isOpen &&\n      `\n      margin-bottom: -${spacing.xsmall};\n      margin-top: -${spacing.xsmall};\n      transition: margin ${animations.durations.superFast} ease;\n    `}\n    ${(props) =>\n      props.isOpen &&\n      `\n      a span {\n        ${animations.fadeInLeftFromZero()}\n        animation-delay: ${parseInt(animations.durations.superFast) * 1.5 + 20 * props.indexNumber}ms;\n      }\n    `}\n    &:first-of-type, &:last-of-type {\n      margin-top: 0;\n      margin-bottom: 0;\n    }\n  }\n  ${(props) =>\n    props.current &&\n    props.isOpen &&\n    `\n    a {\n      &:before {\n        position: absolute;\n        content: '';\n        display: block;\n        background: #fff;\n        height: ${spacing.large};\n        width: calc(${SIDE_NAV_WIDTH} - ${spacing.small});\n        transform: translateX(-${spacing.small});\n      }\n    }\n  `}\n  ${(props) =>\n    props.current &&\n    `\n      background: #fff;\n  `}\n  &:after {\n    content: '';\n    display: block;\n    height: ${spacing.large};\n    width: 2px;\n    background: ${colors.brand.greyLight};\n    position: absolute;\n    transform: translate(29px, -${spacingUnit * 3}px);\n  }\n  ${(props) =>\n    !props.afterCurrent &&\n    `\n    a {\n      > span {\n        color: ${colors.text.primary};\n        font-weight: ${fonts.weight.normal};\n      }\n      color: ${colors.text.primary};\n      font-weight: ${fonts.weight.normal};\n    }\n    &:after {\n      width: 4px;\n      background: ${colors.text.light};\n      transform: translate(28px, -${spacingUnit * 3}px);\n    }\n  `}\n  ${(props) =>\n    !props.afterCurrent &&\n    !props.current &&\n    props.invertedStyle &&\n    `\n    ${mq.range({ from: breakpoints.tablet })} {\n      a {\n        > span {\n          color: #fff;\n        }\n        color: #fff;\n      }\n    }\n    `}\n`;\n\nconst StyledContentType = styled.div`\n  position: relative;\n  z-index: 1;\n  margin-right: ${spacingUnit * 0.75}px;\n  max-height: 36px;\n`;\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ntype StyledNavigationProps = {\n  isOpen: boolean;\n  invertedStyle?: boolean;\n};\n\nconst StyledNavigation = styled.nav<StyledNavigationProps>`\n  > ul {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n  margin-bottom: ${spacing.medium};\n  ${(props) =>\n    !props.isOpen &&\n    css`\n      ${mq.range({ until: breakpoints.tablet })} {\n        margin-left: -28px;\n      }\n      ${mq.range({ from: breakpoints.tablet, until: breakpoints.desktop })} {\n        ${StyledMenuItem} {\n          span {\n            display: none;\n          }\n          &:first-of-type {\n            &:after {\n              display: none !important;\n            }\n          }\n          a:hover,\n          a:focus {\n            position: relative;\n            z-index: 1;\n            width: ${SIDE_NAV_WIDTH};\n            background: ${colors.brand.greyLighter};\n            span {\n              display: flex;\n            }\n          }\n        }\n      }\n    `}\n`;\n\nconst ReadIcon = styled.div`\n  border-radius: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: -6px;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  background: ${colors.brand.secondary};\n  color: ${colors.text.light};\n  transform: translateX(4px);\n  svg {\n    width: 12px;\n    height: 12px;\n    fill: ${colors.brand.lighter};\n  }\n`;\n\ntype Props = {\n  learningsteps: StepProps[];\n  learningPathId: number;\n  isOpen: boolean;\n  toLearningPathUrl(pathId: number, stepId: number): string;\n  currentIndex: number;\n  invertedStyle?: boolean;\n  cookies: {\n    [key: string]: string;\n  };\n  onStepNavigate: () => void;\n};\n\nconst hasRead = (\n  id: number,\n  cookies: {\n    [key: string]: string;\n  },\n) => !!cookies[id];\n\nconst LearningPathMenuContent = ({\n  isOpen,\n  currentIndex,\n  cookies,\n  learningPathId,\n  learningsteps,\n  toLearningPathUrl,\n  invertedStyle,\n  onStepNavigate,\n}: Props) => {\n  return (\n    <StyledNavigation isOpen={isOpen} invertedStyle={invertedStyle}>\n      <ul>\n        {learningsteps.map(({ id, title, type }: StepProps, index: number) => (\n          <StyledMenuItem\n            key={id}\n            current={index === currentIndex}\n            afterCurrent={index > currentIndex}\n            isOpen={isOpen}\n            invertedStyle={invertedStyle}\n            indexNumber={index}>\n            <SafeLink\n              onClick={onStepNavigate}\n              to={toLearningPathUrl(learningPathId, id)}\n              aria-describedby={`read-${id}`}>\n              <StyledContentType>\n                <ContentTypeBadge type={type ?? constants.contentTypes.LEARNING_PATH} background size=\"small\" />\n                {hasRead(id, cookies) && (\n                  <div id={`read-${id}`} aria-hidden>\n                    <HiddenSpan>Lest</HiddenSpan>\n                    <ReadIcon>\n                      <LearningPathRead />\n                    </ReadIcon>\n                  </div>\n                )}\n              </StyledContentType>\n              <span>{title}</span>\n            </SafeLink>\n          </StyledMenuItem>\n        ))}\n      </ul>\n    </StyledNavigation>\n  );\n};\n\nexport default LearningPathMenuContent;\n"]} */"));
70
74
  var hasRead = function hasRead(id, cookies) {
71
75
  return !!cookies[id];
72
76
  };
@@ -79,20 +83,6 @@ var LearningPathMenuContent = function LearningPathMenuContent(_ref2) {
79
83
  toLearningPathUrl = _ref2.toLearningPathUrl,
80
84
  invertedStyle = _ref2.invertedStyle,
81
85
  onStepNavigate = _ref2.onStepNavigate;
82
- var getContentTypeBadge = function getContentTypeBadge(type) {
83
- if (!type) {
84
- return (0, _jsxRuntime.jsx)(_ContentTypeBadge["default"], {
85
- type: _model["default"].contentTypes.LEARNING_PATH,
86
- background: true,
87
- size: "small"
88
- });
89
- }
90
- return (0, _jsxRuntime.jsx)(_ContentTypeBadge["default"], {
91
- type: type,
92
- background: true,
93
- size: "small"
94
- });
95
- };
96
86
  return (0, _jsxRuntime.jsx)(StyledNavigation, {
97
87
  isOpen: isOpen,
98
88
  invertedStyle: invertedStyle,
@@ -110,9 +100,20 @@ var LearningPathMenuContent = function LearningPathMenuContent(_ref2) {
110
100
  children: (0, _jsxRuntime.jsxs)(_safelink["default"], {
111
101
  onClick: onStepNavigate,
112
102
  to: toLearningPathUrl(learningPathId, id),
103
+ "aria-describedby": "read-".concat(id),
113
104
  children: [(0, _jsxRuntime.jsxs)(StyledContentType, {
114
- children: [getContentTypeBadge(type), hasRead(id, cookies) && (0, _jsxRuntime.jsx)(ReadIcon, {
115
- children: (0, _jsxRuntime.jsx)(_contentType.LearningPathRead, {})
105
+ children: [(0, _jsxRuntime.jsx)(_ContentTypeBadge["default"], {
106
+ type: type !== null && type !== void 0 ? type : _model["default"].contentTypes.LEARNING_PATH,
107
+ background: true,
108
+ size: "small"
109
+ }), hasRead(id, cookies) && (0, _jsxRuntime.jsxs)("div", {
110
+ id: "read-".concat(id),
111
+ "aria-hidden": true,
112
+ children: [(0, _jsxRuntime.jsx)(HiddenSpan, {
113
+ children: "Lest"
114
+ }), (0, _jsxRuntime.jsx)(ReadIcon, {
115
+ children: (0, _jsxRuntime.jsx)(_contentType.LearningPathRead, {})
116
+ })]
116
117
  })]
117
118
  }), (0, _jsxRuntime.jsx)("span", {
118
119
  children: title
package/lib/i18n/i18n.js CHANGED
@@ -11,6 +11,7 @@ var _messagesEn = _interopRequireDefault(require("../locale/messages-en"));
11
11
  var _messagesNn = _interopRequireDefault(require("../locale/messages-nn"));
12
12
  var _messagesNb = _interopRequireDefault(require("../locale/messages-nb"));
13
13
  var _messagesSe = _interopRequireDefault(require("../locale/messages-se"));
14
+ var _messagesSma = _interopRequireDefault(require("../locale/messages-sma"));
14
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
15
16
  /*
16
17
  * Copyright (c) 2021-present, NDLA.
@@ -31,7 +32,7 @@ i18nInstance.init({
31
32
  compatibilityJSON: 'v3',
32
33
  detection: DETECTION_OPTIONS,
33
34
  fallbackLng: 'nb',
34
- supportedLngs: ['nb', 'nn', 'en', 'se'],
35
+ supportedLngs: ['nb', 'nn', 'en', 'se', 'sma'],
35
36
  resources: {
36
37
  en: {
37
38
  translation: _messagesEn["default"]
@@ -44,6 +45,9 @@ i18nInstance.init({
44
45
  },
45
46
  se: {
46
47
  translation: _messagesSe["default"]
48
+ },
49
+ sma: {
50
+ translation: _messagesSma["default"]
47
51
  }
48
52
  }
49
53
  });
@@ -205,6 +205,10 @@ declare const messages: {
205
205
  programme: {
206
206
  grades: string;
207
207
  };
208
+ common: {
209
+ subject: string;
210
+ subject_plural: string;
211
+ };
208
212
  treeStructure: {
209
213
  folderChildOptions: {
210
214
  edit: string;
@@ -801,8 +805,8 @@ declare const messages: {
801
805
  selectLanguage: string;
802
806
  info: string;
803
807
  editorInChief: string;
804
- managingEditor: string;
805
808
  linksHeader: string;
809
+ availabilityLink: string;
806
810
  privacyLink: string;
807
811
  cookiesLink: string;
808
812
  vision: string;
@@ -864,12 +868,14 @@ declare const messages: {
864
868
  nb: string;
865
869
  nn: string;
866
870
  se: string;
871
+ sma: string;
867
872
  en: string;
868
873
  };
869
874
  currentLanguageText: {
870
875
  nb: string;
871
876
  nn: string;
872
877
  se: string;
878
+ sma: string;
873
879
  en: string;
874
880
  };
875
881
  breadcrumb: {
@@ -19,6 +19,10 @@ exports.subjectCategories = subjectCategories;
19
19
  exports.contentTypes = contentTypes;
20
20
  var titleTemplate = ' - NDLA';
21
21
  var messages = _objectSpread(_objectSpread({
22
+ common: {
23
+ subject: 'Subject',
24
+ subject_plural: 'Subjects'
25
+ },
22
26
  treeStructure: {
23
27
  folderChildOptions: {
24
28
  edit: 'Edit foldername',
@@ -595,9 +599,9 @@ var messages = _objectSpread(_objectSpread({
595
599
  socialMedia: 'Social media',
596
600
  selectLanguage: 'Choose language (språk): ',
597
601
  info: 'This webapplication is developed by NDLA as Open Source code.',
598
- editorInChief: 'Editor in chief: ',
599
- managingEditor: 'Managing editor: ',
602
+ editorInChief: 'Editor in chief:',
600
603
  linksHeader: 'Other NDLA sites',
604
+ availabilityLink: 'Availability statement',
601
605
  privacyLink: 'Privacy statement',
602
606
  cookiesLink: 'Statement about cookies',
603
607
  vision: 'We create the learning of the future together',
@@ -659,12 +663,14 @@ var messages = _objectSpread(_objectSpread({
659
663
  nb: 'Endre språk til bokmål',
660
664
  nn: 'Endre språk til nynorsk',
661
665
  se: 'Rievdat giela davvisámegiella',
666
+ sma: 'Jarkelh åarjelsaemiene',
662
667
  en: 'Change language to English'
663
668
  },
664
669
  currentLanguageText: {
665
670
  nb: 'Sidene vises på bokmål',
666
671
  nn: 'Sidene vises på nynorsk',
667
672
  se: 'Siiddut leat davvisámegiellii',
673
+ sma: 'Sæjroeh åarjelsaemiene',
668
674
  en: 'Not all pages are available in English. These will be shown in Norwegian'
669
675
  },
670
676
  breadcrumb: {
@@ -205,6 +205,10 @@ declare const messages: {
205
205
  programme: {
206
206
  grades: string;
207
207
  };
208
+ common: {
209
+ subject: string;
210
+ subject_plural: string;
211
+ };
208
212
  treeStructure: {
209
213
  folderChildOptions: {
210
214
  edit: string;
@@ -803,7 +807,7 @@ declare const messages: {
803
807
  linksHeader: string;
804
808
  info: string;
805
809
  editorInChief: string;
806
- managingEditor: string;
810
+ availabilityLink: string;
807
811
  privacyLink: string;
808
812
  cookiesLink: string;
809
813
  socialMediaLinks: {
@@ -864,12 +868,14 @@ declare const messages: {
864
868
  nb: string;
865
869
  nn: string;
866
870
  se: string;
871
+ sma: string;
867
872
  en: string;
868
873
  };
869
874
  currentLanguageText: {
870
875
  nb: string;
871
876
  nn: string;
872
877
  se: string;
878
+ sma: string;
873
879
  en: string;
874
880
  };
875
881
  breadcrumb: {
@@ -19,6 +19,10 @@ exports.subjectCategories = subjectCategories;
19
19
  exports.contentTypes = contentTypes;
20
20
  var titleTemplate = ' - NDLA';
21
21
  var messages = _objectSpread(_objectSpread({
22
+ common: {
23
+ subject: 'Fag',
24
+ subject_plural: 'Fag'
25
+ },
22
26
  treeStructure: {
23
27
  folderChildOptions: {
24
28
  edit: 'Endre mappenavn',
@@ -597,8 +601,8 @@ var messages = _objectSpread(_objectSpread({
597
601
  vision: 'Sammen skaper vi framtidas læring',
598
602
  linksHeader: 'Andre NDLA-nettsteder',
599
603
  info: 'Nettstedet er utarbeidet av NDLA med åpen kildekode.',
600
- editorInChief: 'Ansvarlig redaktør: ',
601
- managingEditor: 'Utgaveansvarlig: ',
604
+ editorInChief: 'Ansvarlig redaktør:',
605
+ availabilityLink: 'Tilgjengelighetserklæring',
602
606
  privacyLink: 'Personvernerklæring',
603
607
  cookiesLink: 'Erklæring om informasjonskapsler',
604
608
  socialMediaLinks: {
@@ -659,12 +663,14 @@ var messages = _objectSpread(_objectSpread({
659
663
  nb: 'Endre språk til bokmål',
660
664
  nn: 'Endre språk til nynorsk',
661
665
  se: 'Rievdat giela davvisámegiella',
666
+ sma: 'Jarkelh åarjelsaemiene',
662
667
  en: 'Change language to English'
663
668
  },
664
669
  currentLanguageText: {
665
670
  nb: 'Sidene vises på bokmål',
666
671
  nn: 'Sidene vises på nynorsk',
667
672
  se: 'Siiddut leat davvisámegiellii',
673
+ sma: 'Sæjroeh åarjelsaemiene',
668
674
  en: 'Not all pages are available in English. These will be shown in Norwegian'
669
675
  },
670
676
  breadcrumb: {
@@ -1107,7 +1113,7 @@ var messages = _objectSpread(_objectSpread({
1107
1113
  },
1108
1114
  newFavourite: 'Nylig lagt til',
1109
1115
  feide: 'Dette henter vi om deg gjennom Feide',
1110
- feideWrongInfo: 'Dersom informasjon er feil, så må dette oppdateres av vertsorganisasjon/skoleeier som brukeren tilhører. Oversikt over brukerstøtte finnes her: feide.no/brukerstøtte',
1116
+ feideWrongInfo: 'Dersom informasjon er feil, så må dette oppdateres av vertsorganisasjon/skoleeier som brukeren tilhører. Oversikt over brukerstøtte finnes her: feide.no/brukerstotte',
1111
1117
  storageInfo: {
1112
1118
  title: 'Slik lagrer du favorittressursene dine fra NDLA',
1113
1119
  text: 'Klikk på hjerteknappen for å lagre en ressurs. Du vil da få mulighet til å lagre ressursen i ei mappe.'
@@ -205,6 +205,10 @@ declare const messages: {
205
205
  programme: {
206
206
  grades: string;
207
207
  };
208
+ common: {
209
+ subject: string;
210
+ subject_plural: string;
211
+ };
208
212
  treeStructure: {
209
213
  folderChildOptions: {
210
214
  edit: string;
@@ -803,7 +807,7 @@ declare const messages: {
803
807
  linksHeader: string;
804
808
  info: string;
805
809
  editorInChief: string;
806
- managingEditor: string;
810
+ availabilityLink: string;
807
811
  privacyLink: string;
808
812
  cookiesLink: string;
809
813
  socialMediaLinks: {
@@ -864,12 +868,14 @@ declare const messages: {
864
868
  nb: string;
865
869
  nn: string;
866
870
  se: string;
871
+ sma: string;
867
872
  en: string;
868
873
  };
869
874
  currentLanguageText: {
870
875
  nb: string;
871
876
  nn: string;
872
877
  se: string;
878
+ sma: string;
873
879
  en: string;
874
880
  };
875
881
  breadcrumb: {
@@ -19,6 +19,10 @@ exports.subjectCategories = subjectCategories;
19
19
  exports.contentTypes = contentTypes;
20
20
  var titleTemplate = ' - NDLA';
21
21
  var messages = _objectSpread(_objectSpread({
22
+ common: {
23
+ subject: 'Fag',
24
+ subject_plural: 'Fag'
25
+ },
22
26
  treeStructure: {
23
27
  folderChildOptions: {
24
28
  edit: 'Endre mappenamn',
@@ -597,8 +601,8 @@ var messages = _objectSpread(_objectSpread({
597
601
  vision: 'Saman skapar vi framtidas læring',
598
602
  linksHeader: 'Andre NDLA-nettstader',
599
603
  info: 'Nettstaden er utarbeida av NDLA med open kjeldekode.',
600
- editorInChief: 'Ansvarleg redaktør: ',
601
- managingEditor: 'Utgåveansvarleg: ',
604
+ editorInChief: 'Ansvarleg redaktør:',
605
+ availabilityLink: 'Tilgjengelegheitserklæring',
602
606
  privacyLink: 'Personvernerklæring',
603
607
  cookiesLink: 'Erklæring om informasjonskapslar',
604
608
  socialMediaLinks: {
@@ -659,12 +663,14 @@ var messages = _objectSpread(_objectSpread({
659
663
  nb: 'Endre språk til bokmål',
660
664
  nn: 'Endre språk til nynorsk',
661
665
  se: 'Rievdat giela davvisámegiella',
666
+ sma: 'Jarkelh åarjelsaemiene',
662
667
  en: 'Change language to English'
663
668
  },
664
669
  currentLanguageText: {
665
670
  nb: 'Sidene blir viste på bokmål',
666
671
  nn: 'Sidene blir viste på nynorsk',
667
672
  se: 'Siiddut leat davvisámegiellii',
673
+ sma: 'Sæjroeh åarjelsaemiene',
668
674
  en: 'Not all pages are available in English. These will be shown in Norwegian'
669
675
  },
670
676
  breadcrumb: {
@@ -1107,7 +1113,7 @@ var messages = _objectSpread(_objectSpread({
1107
1113
  },
1108
1114
  newFavourite: 'Nyleg lagt til',
1109
1115
  feide: 'Dette hentar vi om deg gjennom Feide',
1110
- feideWrongInfo: 'Dersom informasjon er feil, så må dette oppdaterast av vertsorganisasjon/skuleeigar som brukaren tilhøyrer. Oversyn over brukartrygd finst her: feide.no/brukartrygd',
1116
+ feideWrongInfo: 'Dersom informasjon er feil, så må dette oppdaterast av vertsorganisasjon/skuleeigar som brukaren tilhøyrer. Oversyn over brukarstøtte finst her: feide.no/brukerstotte',
1111
1117
  storageInfo: {
1112
1118
  title: 'Slik lagrar du favorittressursane dine frå NDLA',
1113
1119
  text: 'Klikk på hjarteknappen for å lagre ein ressurs. Du vil då få høve til å lagre ressursen i ei mappe.'