@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/Footer/EditorName.js +1 -1
- package/es/LearningPaths/LearningPathMenuContent.js +25 -24
- package/es/i18n/i18n.js +5 -1
- package/es/locale/messages-en.js +8 -2
- package/es/locale/messages-nb.js +9 -3
- package/es/locale/messages-nn.js +9 -3
- package/es/locale/messages-se.js +13 -7
- package/es/locale/messages-sma.js +481 -475
- package/es/types.js +1 -1
- package/lib/Footer/EditorName.js +1 -1
- package/lib/LearningPaths/LearningPathMenuContent.js +24 -23
- package/lib/i18n/i18n.js +5 -1
- package/lib/locale/messages-en.d.ts +7 -1
- package/lib/locale/messages-en.js +8 -2
- package/lib/locale/messages-nb.d.ts +7 -1
- package/lib/locale/messages-nb.js +9 -3
- package/lib/locale/messages-nn.d.ts +7 -1
- package/lib/locale/messages-nn.js +9 -3
- package/lib/locale/messages-se.d.ts +7 -1
- package/lib/locale/messages-se.js +13 -7
- package/lib/locale/messages-sma.d.ts +8 -2
- package/lib/locale/messages-sma.js +481 -475
- package/lib/types.d.ts +1 -1
- package/lib/types.js +1 -1
- package/package.json +12 -12
- package/src/Footer/EditorName.tsx +2 -1
- package/src/LearningPaths/LearningPathMenuContent.tsx +16 -12
- package/src/i18n/i18n.ts +5 -1
- package/src/locale/messages-en.ts +8 -2
- package/src/locale/messages-nb.ts +9 -3
- package/src/locale/messages-nn.ts +9 -3
- package/src/locale/messages-se.ts +13 -7
- package/src/locale/messages-sma.ts +504 -495
- package/src/types.ts +1 -1
package/es/types.js
CHANGED
package/lib/Footer/EditorName.js
CHANGED
|
@@ -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: "
|
|
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,
|
|
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: "
|
|
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,
|
|
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,
|
|
65
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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,
|
|
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: [
|
|
115
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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/
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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.'
|