@ndla/ui 3.0.12 → 3.0.15
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/ResourceGroup/ResourceItem.js +13 -13
- package/es/index.js +1 -2
- package/es/locale/messages-en.js +7 -2
- package/es/locale/messages-nb.js +7 -2
- package/es/locale/messages-nn.js +7 -2
- package/lib/ResourceGroup/ResourceItem.js +14 -14
- package/lib/index.d.ts +0 -1
- package/lib/index.js +1 -10
- package/lib/locale/messages-en.d.ts +5 -0
- package/lib/locale/messages-en.js +7 -2
- package/lib/locale/messages-nb.d.ts +5 -0
- package/lib/locale/messages-nb.js +7 -2
- package/lib/locale/messages-nn.d.ts +5 -0
- package/lib/locale/messages-nn.js +7 -2
- package/package.json +2 -2
- package/src/ResourceGroup/ResourceItem.tsx +2 -2
- package/src/index.ts +0 -1
- package/src/locale/messages-en.ts +6 -1
- package/src/locale/messages-nb.ts +6 -1
- package/src/locale/messages-nn.ts +6 -1
- package/es/Matomo/MatomoTracker.js +0 -19
- package/es/Matomo/index.js +0 -9
- package/lib/Matomo/MatomoTracker.d.ts +0 -6
- package/lib/Matomo/MatomoTracker.js +0 -33
- package/lib/Matomo/index.d.ts +0 -9
- package/lib/Matomo/index.js +0 -20
- package/src/Matomo/MatomoTracker.tsx +0 -36
- package/src/Matomo/index.ts +0 -11
|
@@ -13,12 +13,12 @@ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
|
|
|
13
13
|
|
|
14
14
|
var _react = _interopRequireDefault(require("react"));
|
|
15
15
|
|
|
16
|
+
var _reactI18next = require("react-i18next");
|
|
17
|
+
|
|
16
18
|
var _core = require("@emotion/core");
|
|
17
19
|
|
|
18
20
|
var _safelink = _interopRequireDefault(require("@ndla/safelink"));
|
|
19
21
|
|
|
20
|
-
var _reactI18next = require("react-i18next");
|
|
21
|
-
|
|
22
22
|
var _common = require("@ndla/icons/common");
|
|
23
23
|
|
|
24
24
|
var _core2 = require("@ndla/core");
|
|
@@ -81,26 +81,26 @@ var ListElement = (0, _styledBase["default"])("li", {
|
|
|
81
81
|
target: "ehgdkrx0",
|
|
82
82
|
label: "ListElement"
|
|
83
83
|
})("border:1px solid #d1d6db;border-radius:5px;background:", _core2.colors.white, ";margin-bottom:", _core2.spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding-right:1rem;", function (props) {
|
|
84
|
-
return props.additional && /*#__PURE__*/(0, _css2["default"])("border-style:dashed;animation-name:", fadeInAdditionalsKeyframe, ";animation-duration:0.8s;animation-fill-mode:forwards;;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoFO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
84
|
+
return props.additional && /*#__PURE__*/(0, _css2["default"])("border-style:dashed;animation-name:", fadeInAdditionalsKeyframe, ";animation-duration:0.8s;animation-fill-mode:forwards;;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoFO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
85
85
|
}, " ", function (props) {
|
|
86
86
|
return props.extraBottomMargin && "margin-bottom: ".concat(_core2.spacing.large, ";");
|
|
87
87
|
}, " *{transition:height ease-out 0.2s,width ease-out 0.2s;}", function (props) {
|
|
88
88
|
return props.active && /*#__PURE__*/(0, _css2["default"])("&:before{", _core2.mq.range({
|
|
89
89
|
from: _core2.breakpoints.tablet
|
|
90
|
-
}), "{content:'';display:block;position:absolute;width:", _core2.spacing.small, ";height:", _core2.spacing.small, ";border-radius:100%;transform:translate(calc(-", _core2.spacing.normal, " - ", _core2.spacing.small, "));background-color:", listElementActiveColor(props.contentType), ";}};label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiGO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
90
|
+
}), "{content:'';display:block;position:absolute;width:", _core2.spacing.small, ";height:", _core2.spacing.small, ";border-radius:100%;transform:translate(calc(-", _core2.spacing.normal, " - ", _core2.spacing.small, "));background-color:", listElementActiveColor(props.contentType), ";}};label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiGO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
91
91
|
}, " ", function (_ref) {
|
|
92
92
|
var hidden = _ref.hidden;
|
|
93
93
|
return hidden && "display:none; opacity:0;";
|
|
94
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwE+C","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
95
|
-
var LinkStyle = /*#__PURE__*/(0, _css2["default"])("display:flex;color:", _core2.colors.brand.dark, ";align-items:center;width:auto;padding:", _core2.spacing.small, ";box-shadow:none;min-height:70px;;label:LinkStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkHqB","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
94
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwE+C","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
95
|
+
var LinkStyle = /*#__PURE__*/(0, _css2["default"])("display:flex;color:", _core2.colors.brand.dark, ";align-items:center;width:auto;padding:", _core2.spacing.small, ";box-shadow:none;min-height:70px;;label:LinkStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkHqB","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
96
96
|
var ActiveWrapper = (0, _styledBase["default"])("div", {
|
|
97
97
|
target: "ehgdkrx1",
|
|
98
98
|
label: "ActiveWrapper"
|
|
99
|
-
})(LinkStyle, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4HgC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
99
|
+
})(LinkStyle, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA4HgC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
100
100
|
var ResourceLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
|
|
101
101
|
target: "ehgdkrx2",
|
|
102
102
|
label: "ResourceLink"
|
|
103
|
-
})(LinkStyle, " &:hover .c-content-type-badge{width:38px;height:38px;svg{width:20px;height:20px;}&.c-content-type-badge--subject-material,&.c-content-type-badge--learning-path,&.c-content-type-badge--source-material,&.c-content-type-badge--external-learning-resources{svg{width:26px;height:26px;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+HqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
103
|
+
})(LinkStyle, " &:hover .c-content-type-badge{width:38px;height:38px;svg{width:20px;height:20px;}&.c-content-type-badge--subject-material,&.c-content-type-badge--learning-path,&.c-content-type-badge--source-material,&.c-content-type-badge--external-learning-resources{svg{width:26px;height:26px;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+HqC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
104
104
|
var Heading = (0, _styledBase["default"])("h2", {
|
|
105
105
|
target: "ehgdkrx3",
|
|
106
106
|
label: "Heading"
|
|
@@ -109,8 +109,8 @@ var Heading = (0, _styledBase["default"])("h2", {
|
|
|
109
109
|
}), "{", _core2.fonts.sizes('18px', '26px'), ";}", _core2.mq.range({
|
|
110
110
|
from: _core2.breakpoints.desktop
|
|
111
111
|
}), "{", _core2.fonts.sizes('20px', '26px'), ";}span{box-shadow:", _core2.colors.link, ";}", ResourceLink, ":hover &,", ResourceLink, ":focus &{span{box-shadow:", _core2.colors.linkHover, ";}}", function (props) {
|
|
112
|
-
return props.active && /*#__PURE__*/(0, _css2["default"])("color:", _core2.colors.brand.greyDark, ";span{box-shadow:none;}small{padding-left:", _core2.spacing.small, ";font-weight:", _core2.fonts.weight.normal, ";};label:Heading;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAmLO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
113
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwJsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
112
|
+
return props.active && /*#__PURE__*/(0, _css2["default"])("color:", _core2.colors.brand.greyDark, ";span{box-shadow:none;}small{padding-left:", _core2.spacing.small, ";font-weight:", _core2.fonts.weight.normal, ";};label:Heading;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAmLO","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
113
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwJsC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */");
|
|
114
114
|
var IconWrapper = (0, _styledBase["default"])("div", {
|
|
115
115
|
target: "ehgdkrx4",
|
|
116
116
|
label: "IconWrapper"
|
|
@@ -118,7 +118,7 @@ var IconWrapper = (0, _styledBase["default"])("div", {
|
|
|
118
118
|
from: _core2.breakpoints.tablet
|
|
119
119
|
}), "{padding-right:", _core2.spacing.small, ";padding-left:", _core2.spacing.xsmall, ";}", _core2.mq.range({
|
|
120
120
|
from: _core2.breakpoints.desktop
|
|
121
|
-
}), "{padding-right:", _core2.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+L8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
121
|
+
}), "{padding-right:", _core2.spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+L8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
122
122
|
var TypeWrapper = (0, _styledBase["default"])("div", {
|
|
123
123
|
target: "ehgdkrx5",
|
|
124
124
|
label: "TypeWrapper"
|
|
@@ -128,13 +128,13 @@ var TypeWrapper = (0, _styledBase["default"])("div", {
|
|
|
128
128
|
} : {
|
|
129
129
|
name: "70qvj9",
|
|
130
130
|
styles: "display:flex;align-items:center;",
|
|
131
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkN8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
|
|
131
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkN8B","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
|
|
132
132
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
133
133
|
});
|
|
134
134
|
var ContentTypeName = (0, _styledBase["default"])("span", {
|
|
135
135
|
target: "ehgdkrx6",
|
|
136
136
|
label: "ContentTypeName"
|
|
137
|
-
})("font-family:", _core2.fonts.sans, ";", _core2.fonts.sizes('14px', '18px'), ";font-weight:", _core2.fonts.weight.semibold, ";color:", _core2.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAuNmC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { useTranslation } from 'react-i18next';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
137
|
+
})("font-family:", _core2.fonts.sans, ";", _core2.fonts.sizes('14px', '18px'), ";font-weight:", _core2.fonts.weight.semibold, ";color:", _core2.colors.text.light, ";text-align:right;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAuNmC","file":"ResourceItem.tsx","sourcesContent":["/**\n * Copyright (c) 2021-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 { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport css from '@emotion/css';\nimport { keyframes } from '@emotion/core';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\n\n// @ts-ignore\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\n// @ts-ignore\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport * as contentTypes from '../model/ContentType';\n\nconst listElementActiveColor = (contentType?: string) => {\n  switch (contentType) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.dark;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.dark;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.dark;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.dark;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.dark;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.dark;\n    default:\n      break;\n  }\n  return 'none';\n};\n\nconst fadeInAdditionalsKeyframe = keyframes`\n  0% {\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n    position: absolute;\n  }\n  49% {\n    position: absolute;\n  }\n  50% {\n    position: static;\n    opacity: 0;\n    transform: translate3d(-10px, 0px, 0px);\n  }\n  100% {\n    position: static;\n    opacity: 1;\n    height: auto;\n  }\n`;\n\ntype ListElementProps = {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n};\nconst ListElement = styled.li<ListElementProps>`\n  border: 1px solid #d1d6db;\n  border-radius: 5px;\n  background: ${colors.white};\n  margin-bottom: ${spacing.xsmall};\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding-right: 1rem;\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-name: ${fadeInAdditionalsKeyframe};\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n    `}\n  ${(props) => props.extraBottomMargin && `margin-bottom: ${spacing.large};`}\n\n  * {\n    transition: height ease-out 0.2s, width ease-out 0.2s;\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      &:before {\n        ${mq.range({ from: breakpoints.tablet })} {\n          content: '';\n          display: block;\n          position: absolute;\n          width: ${spacing.small};\n          height: ${spacing.small};\n          border-radius: 100%;\n          transform: translate(calc(-${spacing.normal} - ${spacing.small}));\n          background-color: ${listElementActiveColor(props.contentType)};\n        }\n      }\n    `}\n  ${({ hidden }) => hidden && `display:none; opacity:0;`}\n`;\n\nconst LinkStyle = css`\n  display: flex;\n  color: ${colors.brand.dark};\n  align-items: center;\n  width: auto;\n  padding: ${spacing.small};\n  box-shadow: none;\n  min-height: 70px;\n`;\n\nconst ActiveWrapper = styled.div`\n  ${LinkStyle}\n`;\nconst ResourceLink = styled(SafeLink)`\n  ${LinkStyle}\n  &:hover .c-content-type-badge {\n    width: 38px;\n    height: 38px;\n\n    svg {\n      width: 20px;\n      height: 20px;\n    }\n    &.c-content-type-badge--subject-material,\n    &.c-content-type-badge--learning-path,\n    &.c-content-type-badge--source-material,\n    &.c-content-type-badge--external-learning-resources {\n      svg {\n        width: 26px;\n        height: 26px;\n      }\n    }\n  }\n`;\n\ntype ActiveProps = {\n  active?: boolean;\n};\nconst Heading = styled.h2<ActiveProps>`\n  font-weight: ${fonts.weight.semibold};\n  transform: translateY(-1px);\n  text-transform: none;\n  letter-spacing: 0;\n  margin: 0;\n  display: inline;\n  ${fonts.sizes('16px', '26px')};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes('18px', '26px')};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    ${fonts.sizes('20px', '26px')};\n  }\n\n  span {\n    box-shadow: ${colors.link};\n  }\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    span {\n      box-shadow: ${colors.linkHover};\n    }\n  }\n  ${(props) =>\n    props.active &&\n    css`\n      color: ${colors.brand.greyDark};\n      span {\n        box-shadow: none;\n      }\n      small {\n        padding-left: ${spacing.small};\n        font-weight: ${fonts.weight.normal};\n      }\n    `}\n`;\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex: 0 0 auto;\n  text-align: center;\n  justify-content: center;\n  align-items: center;\n  width: 42px;\n  height: 42px;\n  box-sizing: content-box;\n  padding-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-right: ${spacing.small};\n    padding-left: ${spacing.xsmall};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-right: ${spacing.nsmall};\n  }\n`;\n\nconst TypeWrapper = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ContentTypeName = styled.span`\n  font-family: ${fonts.sans};\n  ${fonts.sizes('14px', '18px')};\n  font-weight: ${fonts.weight.semibold};\n  color: ${colors.text.light};\n  text-align: right;\n`;\n\ntype Props = {\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n};\n\nconst ResourceItem = ({\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      {active ? (\n        <ActiveWrapper>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading active>\n            <span>\n              {name}\n              <small>{t('resource.youAreHere')}</small>\n            </span>\n          </Heading>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <Heading>\n            <span>{name}</span>\n          </Heading>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')} align=\"left\">\n            <HumanMaleBoard className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Additional className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription} align=\"left\">\n                <Core className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\" />\n              </Tooltip>\n            )}\n          </>\n        )}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
138
138
|
|
|
139
139
|
var ResourceItem = function ResourceItem(_ref2) {
|
|
140
140
|
var contentTypeName = _ref2.contentTypeName,
|
|
@@ -154,7 +154,7 @@ var ResourceItem = function ResourceItem(_ref2) {
|
|
|
154
154
|
var hidden = additional ? !showAdditionalResources : false;
|
|
155
155
|
return (0, _core.jsx)(ListElement, {
|
|
156
156
|
contentType: contentType,
|
|
157
|
-
hidden: hidden,
|
|
157
|
+
hidden: hidden && !active,
|
|
158
158
|
active: active,
|
|
159
159
|
additional: additional,
|
|
160
160
|
extraBottomMargin: extraBottomMargin
|