@ndla/ui 34.0.1 → 34.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Figure/Figure.js +3 -2
- package/es/FileList/File.js +6 -6
- package/es/LanguageSelector/LanguageSelector.js +67 -99
- package/es/NDLAFilm/AboutNdlaFilm.js +13 -12
- package/es/NDLAFilm/AllMoviesAlphabetically.js +79 -144
- package/es/NDLAFilm/FilmContentCard.js +41 -26
- package/es/NDLAFilm/FilmContentCardTags.js +5 -3
- package/es/NDLAFilm/FilmMovieList.js +13 -8
- package/es/NDLAFilm/FilmMovieSearch.js +6 -5
- package/es/NDLAFilm/FilmSlideshow.js +44 -20
- package/es/NDLAFilm/filmStyles.js +2 -2
- package/es/ResourceGroup/ResourceItem.js +72 -48
- package/es/Search/ActiveFilterContent.js +6 -5
- package/es/Search/ContentTypeResult.js +6 -3
- package/es/SearchTypeResult/ActiveFilterContent.js +9 -10
- package/es/Topic/Topic.js +171 -213
- package/es/all.css +1 -1
- package/es/locale/messages-en.js +3 -1
- package/es/locale/messages-nb.js +3 -1
- package/es/locale/messages-nn.js +7 -5
- package/es/locale/messages-se.js +2 -0
- package/es/locale/messages-sma.js +3 -1
- package/lib/Figure/Figure.d.ts +2 -1
- package/lib/Figure/Figure.js +3 -2
- package/lib/FileList/File.js +6 -6
- package/lib/LanguageSelector/LanguageSelector.d.ts +6 -15
- package/lib/LanguageSelector/LanguageSelector.js +64 -99
- package/lib/NDLAFilm/AboutNdlaFilm.js +11 -14
- package/lib/NDLAFilm/AllMoviesAlphabetically.d.ts +1 -2
- package/lib/NDLAFilm/AllMoviesAlphabetically.js +77 -142
- package/lib/NDLAFilm/FilmContentCard.d.ts +7 -0
- package/lib/NDLAFilm/FilmContentCard.js +41 -26
- package/lib/NDLAFilm/FilmContentCardTags.d.ts +2 -1
- package/lib/NDLAFilm/FilmContentCardTags.js +5 -3
- package/lib/NDLAFilm/FilmMovieList.js +12 -7
- package/lib/NDLAFilm/FilmMovieSearch.js +5 -4
- package/lib/NDLAFilm/FilmSlideshow.js +44 -20
- package/lib/NDLAFilm/filmStyles.js +2 -2
- package/lib/Resource/resourceComponents.d.ts +1 -1
- package/lib/ResourceGroup/ResourceItem.d.ts +2 -2
- package/lib/ResourceGroup/ResourceItem.js +72 -48
- package/lib/Search/ActiveFilterContent.d.ts +1 -1
- package/lib/Search/ActiveFilterContent.js +9 -5
- package/lib/Search/ContentTypeResult.js +6 -3
- package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
- package/lib/SearchTypeResult/ActiveFilterContent.js +12 -10
- package/lib/Topic/Topic.js +170 -215
- package/lib/all.css +1 -1
- package/lib/locale/messages-en.d.ts +2 -0
- package/lib/locale/messages-en.js +3 -1
- package/lib/locale/messages-nb.d.ts +2 -0
- package/lib/locale/messages-nb.js +3 -1
- package/lib/locale/messages-nn.d.ts +4 -2
- package/lib/locale/messages-nn.js +7 -5
- package/lib/locale/messages-se.d.ts +2 -0
- package/lib/locale/messages-se.js +2 -0
- package/lib/locale/messages-sma.d.ts +2 -0
- package/lib/locale/messages-sma.js +3 -1
- package/package.json +15 -14
- package/src/Figure/Figure.tsx +6 -2
- package/src/FileList/File.tsx +4 -4
- package/src/LanguageSelector/LanguageSelector.stories.tsx +48 -0
- package/src/LanguageSelector/LanguageSelector.tsx +70 -149
- package/src/NDLAFilm/AboutNdlaFilm.tsx +11 -14
- package/src/NDLAFilm/AllMoviesAlphabetically.tsx +44 -160
- package/src/NDLAFilm/FilmContentCard.tsx +40 -21
- package/src/NDLAFilm/FilmContentCardTags.tsx +3 -2
- package/src/NDLAFilm/FilmMovieList.tsx +14 -7
- package/src/NDLAFilm/FilmMovieSearch.tsx +2 -2
- package/src/NDLAFilm/FilmSlideshow.tsx +49 -40
- package/src/NDLAFilm/filmStyles.ts +1 -1
- package/src/ResourceGroup/ResourceItem.tsx +79 -94
- package/src/Search/ActiveFilterContent.tsx +4 -3
- package/src/Search/ContentTypeResult.tsx +3 -1
- package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -8
- package/src/Topic/Topic.tsx +166 -193
- package/src/locale/messages-en.ts +3 -1
- package/src/locale/messages-nb.ts +3 -1
- package/src/locale/messages-nn.ts +5 -4
- package/src/locale/messages-se.ts +2 -0
- package/src/locale/messages-sma.ts +3 -1
- package/src/main.scss +0 -1
- package/es/LanguageSelector/LanguageSelectorContent.js +0 -61
- package/es/Subject/SubjectCarousel.js +0 -133
- package/lib/LanguageSelector/LanguageSelectorContent.d.ts +0 -15
- package/lib/LanguageSelector/LanguageSelectorContent.js +0 -68
- package/lib/Subject/SubjectCarousel.d.ts +0 -18
- package/lib/Subject/SubjectCarousel.js +0 -138
- package/src/LanguageSelector/LanguageSelectorContent.tsx +0 -80
- package/src/NDLAFilm/component.film-movielist.scss +0 -105
- package/src/Subject/SubjectCarousel.tsx +0 -162
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
2
|
var _templateObject;
|
|
3
3
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
4
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
4
5
|
/**
|
|
5
6
|
* Copyright (c) 2021-present, NDLA.
|
|
6
7
|
*
|
|
@@ -42,51 +43,76 @@ var listElementActiveColor = function listElementActiveColor(contentType) {
|
|
|
42
43
|
};
|
|
43
44
|
var fadeInAdditionalsKeyframe = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\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"])));
|
|
44
45
|
var ListElement = /*#__PURE__*/_styled("li", {
|
|
45
|
-
target: "
|
|
46
|
+
target: "ehgdkrx8",
|
|
46
47
|
label: "ListElement"
|
|
47
|
-
})("border:1px solid #d1d6db;border-radius:5px;background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding
|
|
48
|
-
return props.additional && /*#__PURE__*/css("border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAgFO","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
48
|
+
})("border:1px solid #d1d6db;border-radius:5px;background:", colors.white, ";margin-bottom:", spacing.xsmall, ";display:flex;justify-content:space-between;align-items:center;padding:", spacing.small, ";", function (props) {
|
|
49
|
+
return props.additional && /*#__PURE__*/css("border-style:dashed;animation-duration:0.8s;animation-fill-mode:forwards;animation:", fadeInAdditionalsKeyframe, ";;label:ListElement;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiFO","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
49
50
|
}, " ", function (props) {
|
|
50
51
|
return props.extraBottomMargin && "margin-bottom: ".concat(spacing.large, ";");
|
|
51
52
|
}, " *{transition:height ease-out 0.2s,width ease-out 0.2s;}", function (props) {
|
|
52
53
|
return props.active && /*#__PURE__*/css("&:before{", mq.range({
|
|
53
54
|
from: breakpoints.tablet
|
|
54
|
-
}), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(calc(-", spacing.normal, " - ", 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":"AA6FO","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
55
|
+
}), "{content:'';display:block;position:absolute;width:", spacing.small, ";height:", spacing.small, ";border-radius:100%;transform:translate(calc(-", spacing.normal, " - ", 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":"AA8FO","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
55
56
|
}, " ", function (_ref) {
|
|
56
57
|
var hidden = _ref.hidden;
|
|
57
58
|
return hidden && "display:none; opacity:0;";
|
|
58
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoE+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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
59
|
-
var LinkStyle = /*#__PURE__*/css("display:flex;color:", colors.brand.dark, ";align-items:center;width:auto;padding:", 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":"AA8GqB","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
60
|
-
var ActiveWrapper = /*#__PURE__*/_styled("div", {
|
|
61
|
-
target: "ehgdkrx4",
|
|
62
|
-
label: "ActiveWrapper"
|
|
63
|
-
})(LinkStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwHgC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
59
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAqE+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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
64
60
|
var ResourceLink = /*#__PURE__*/_styled(SafeLink, {
|
|
65
|
-
target: "
|
|
61
|
+
target: "ehgdkrx7",
|
|
66
62
|
label: "ResourceLink"
|
|
67
|
-
})(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":"AA2HqC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
68
|
-
var headingStyle = /*#__PURE__*/css("font-weight:", fonts.weight.semibold, ";transform:translateY(-1px);text-transform:none;letter-spacing:0;margin:0;display:inline;", fonts.sizes('16px', '26px'), ";", mq.range({
|
|
63
|
+
})("font-weight:", fonts.weight.semibold, ";box-shadow:none;text-decoration:underline;text-underline-offset:5px;color:", colors.brand.dark, ";", fonts.sizes('16px', '26px'), ";", mq.range({
|
|
69
64
|
from: breakpoints.tablet
|
|
70
65
|
}), "{", fonts.sizes('18px', '26px'), ";}", mq.range({
|
|
71
66
|
from: breakpoints.desktop
|
|
72
|
-
}), "{", fonts.sizes('20px', '26px'), ";}box-shadow:", colors.link, ";", ResourceLink, ":hover &,", ResourceLink, ":focus &{box-shadow:", colors.linkHover, ";};label:headingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiJwB","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
73
|
-
var activeHeadingStyle = /*#__PURE__*/css("color:", colors.brand.greyDark, ";box-shadow:none;small{padding-left:", spacing.small, ";font-weight:", fonts.weight.normal, ";};label:activeHeadingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAwK8B","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
label: "IconWrapper"
|
|
67
|
+
}), "{", fonts.sizes('20px', '26px'), ";}&:hover{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+GqC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
68
|
+
var ContentBadgeWrapper = /*#__PURE__*/_styled("div", {
|
|
69
|
+
target: "ehgdkrx6",
|
|
70
|
+
label: "ContentBadgeWrapper"
|
|
77
71
|
})("display:flex;flex:0 0 auto;text-align:center;justify-content:center;align-items:center;width:42px;height:42px;box-sizing:content-box;padding-right:", spacing.small, ";", mq.range({
|
|
78
72
|
from: breakpoints.tablet
|
|
79
73
|
}), "{padding-right:", spacing.small, ";padding-left:", spacing.xsmall, ";}", mq.range({
|
|
80
74
|
from: breakpoints.desktop
|
|
81
|
-
}), "{padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiL8B","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
75
|
+
}), "{padding-right:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAiIsC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
82
76
|
var TypeWrapper = /*#__PURE__*/_styled("div", {
|
|
83
|
-
target: "
|
|
77
|
+
target: "ehgdkrx5",
|
|
84
78
|
label: "TypeWrapper"
|
|
85
|
-
})("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoM8B","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
79
|
+
})("display:flex;align-items:center;gap:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAoJ8B","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
86
80
|
var ContentTypeName = /*#__PURE__*/_styled("span", {
|
|
87
|
-
target: "
|
|
81
|
+
target: "ehgdkrx4",
|
|
88
82
|
label: "ContentTypeName"
|
|
89
|
-
})("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", 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":"AA0MmC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
83
|
+
})("font-family:", fonts.sans, ";", fonts.sizes('14px', '18px'), ";font-weight:", fonts.weight.semibold, ";color:", 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":"AA0JmC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
84
|
+
var InlineContainer = /*#__PURE__*/_styled("div", {
|
|
85
|
+
target: "ehgdkrx3",
|
|
86
|
+
label: "InlineContainer"
|
|
87
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
88
|
+
name: "1u4hpl4",
|
|
89
|
+
styles: "display:inline"
|
|
90
|
+
} : {
|
|
91
|
+
name: "1u4hpl4",
|
|
92
|
+
styles: "display:inline",
|
|
93
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAkKkC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
|
|
94
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
95
|
+
});
|
|
96
|
+
var ResourceWrapper = /*#__PURE__*/_styled("div", {
|
|
97
|
+
target: "ehgdkrx2",
|
|
98
|
+
label: "ResourceWrapper"
|
|
99
|
+
})("display:flex;gap:", spacing.xsmall, ";align-items:center;: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":"AAsKkC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
100
|
+
var CurrentSmall = /*#__PURE__*/_styled("small", {
|
|
101
|
+
target: "ehgdkrx1",
|
|
102
|
+
label: "CurrentSmall"
|
|
103
|
+
})("margin-left:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AAgMiC","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */"));
|
|
104
|
+
var IconWrapper = /*#__PURE__*/_styled("div", {
|
|
105
|
+
target: "ehgdkrx0",
|
|
106
|
+
label: "IconWrapper"
|
|
107
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
108
|
+
name: "ji2k1n",
|
|
109
|
+
styles: "display:flex;flex-grow:1;svg{width:26px;height:26px;}"
|
|
110
|
+
} : {
|
|
111
|
+
name: "ji2k1n",
|
|
112
|
+
styles: "display:flex;flex-grow:1;svg{width:26px;height:26px;}",
|
|
113
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA+M8B","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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\ninterface ListElementProps {\n  additional?: boolean;\n  extraBottomMargin?: boolean;\n  contentType?: string;\n  active?: boolean;\n  hidden?: boolean;\n}\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: ${spacing.small};\n\n  ${(props) =>\n    props.additional &&\n    css`\n      border-style: dashed;\n      animation-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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 ResourceLink = styled(SafeLink)`\n  font-weight: ${fonts.weight.semibold};\n  box-shadow: none;\n  text-decoration: underline;\n  text-underline-offset: 5px;\n  color: ${colors.brand.dark};\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  &:hover {\n    text-decoration: none;\n  }\n`;\n\nconst ContentBadgeWrapper = 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  gap: ${spacing.xsmall};\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\nconst InlineContainer = styled.div`\n  display: inline;\n`;\n\nconst ResourceWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n  :hover {\n    .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`;\n\nconst CurrentSmall = styled.small`\n  margin-left: ${spacing.xsmall};\n`;\n\ninterface Props {\n  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n}\n\nconst IconWrapper = styled.div`\n  display: flex;\n  flex-grow: 1;\n  svg {\n    width: 26px;\n    height: 26px;\n  }\n`;\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const accessId = `${id}-teacher`;\n  const coreId = `${id}-core`;\n  const additionalId = `${id}-additional`;\n  const describedBy = `${coreId} ${additionalId} ${accessId}`;\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\n      contentType={contentType}\n      hidden={hidden && !active}\n      active={active}\n      additional={additional}\n      extraBottomMargin={extraBottomMargin}>\n      <ResourceWrapper>\n        <ContentBadgeWrapper>\n          <ContentTypeBadge type={contentType ?? ''} background border={false} />\n        </ContentBadgeWrapper>\n        <InlineContainer>\n          <ResourceLink to={path} aria-current={active ? 'page' : undefined} aria-describedby={describedBy}>\n            {name}\n          </ResourceLink>\n          {active ? <CurrentSmall>{t('resource.youAreHere')}</CurrentSmall> : undefined}\n        </InlineContainer>\n      </ResourceWrapper>\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <IconWrapper>\n              <HumanMaleBoard id={accessId} aria-label={t('article.access.onlyTeacher')} />\n            </IconWrapper>\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Additional id={additionalId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <IconWrapper>\n                  <Core id={coreId} aria-label={contentTypeDescription} />\n                </IconWrapper>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */",
|
|
114
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
115
|
+
});
|
|
90
116
|
var ResourceItem = function ResourceItem(_ref2) {
|
|
91
117
|
var id = _ref2.id,
|
|
92
118
|
contentTypeName = _ref2.contentTypeName,
|
|
@@ -102,6 +128,10 @@ var ResourceItem = function ResourceItem(_ref2) {
|
|
|
102
128
|
heartButton = _ref2.heartButton;
|
|
103
129
|
var _useTranslation = useTranslation(),
|
|
104
130
|
t = _useTranslation.t;
|
|
131
|
+
var accessId = "".concat(id, "-teacher");
|
|
132
|
+
var coreId = "".concat(id, "-core");
|
|
133
|
+
var additionalId = "".concat(id, "-additional");
|
|
134
|
+
var describedBy = "".concat(coreId, " ").concat(additionalId, " ").concat(accessId);
|
|
105
135
|
var hidden = additional ? !showAdditionalResources : false;
|
|
106
136
|
return _jsxs(ListElement, {
|
|
107
137
|
"aria-current": active ? 'page' : undefined,
|
|
@@ -110,54 +140,48 @@ var ResourceItem = function ResourceItem(_ref2) {
|
|
|
110
140
|
active: active,
|
|
111
141
|
additional: additional,
|
|
112
142
|
extraBottomMargin: extraBottomMargin,
|
|
113
|
-
children: [
|
|
114
|
-
children: [_jsx(
|
|
143
|
+
children: [_jsxs(ResourceWrapper, {
|
|
144
|
+
children: [_jsx(ContentBadgeWrapper, {
|
|
115
145
|
children: _jsx(ContentTypeBadge, {
|
|
116
146
|
type: contentType !== null && contentType !== void 0 ? contentType : '',
|
|
117
147
|
background: true,
|
|
118
148
|
border: false
|
|
119
149
|
})
|
|
120
|
-
}), _jsxs(
|
|
121
|
-
css: [headingStyle, activeHeadingStyle, ";label:ResourceItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ResourceItem.tsx"],"names":[],"mappings":"AA0PgB","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, { ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport SafeLink from '@ndla/safelink';\nimport { Additional, Core, HumanMaleBoard } from '@ndla/icons/common';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport Tooltip from '@ndla/tooltip';\nimport { Resource } from '../types';\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-duration: 0.8s;\n      animation-fill-mode: forwards;\n      animation: ${fadeInAdditionalsKeyframe};\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\nconst headingStyle = css`\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  box-shadow: ${colors.link};\n\n  ${ResourceLink}:hover &,\n  ${ResourceLink}:focus & {\n    box-shadow: ${colors.linkHover};\n  }\n`;\n\nconst activeHeadingStyle = css`\n  color: ${colors.brand.greyDark};\n  box-shadow: none;\n  small {\n    padding-left: ${spacing.small};\n    font-weight: ${fonts.weight.normal};\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  gap: ${spacing.xsmall};\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  id: string;\n  showContentTypeDescription?: boolean;\n  contentTypeName?: string;\n  contentTypeDescription?: string;\n  extraBottomMargin?: boolean;\n  showAdditionalResources?: boolean;\n  access?: 'teacher';\n  heartButton?: (path: string) => ReactNode;\n};\n\nconst ResourceItem = ({\n  id,\n  contentTypeName,\n  contentTypeDescription,\n  name,\n  path,\n  contentType,\n  active,\n  additional,\n  extraBottomMargin,\n  showAdditionalResources,\n  access,\n  heartButton,\n}: Props & Resource) => {\n  const { t } = useTranslation();\n  const hidden = additional ? !showAdditionalResources : false;\n  return (\n    <ListElement\n      aria-current={active ? 'page' : undefined}\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          <span css={[headingStyle, activeHeadingStyle]}>\n            {name}\n            <small>{t('resource.youAreHere')}</small>\n          </span>\n        </ActiveWrapper>\n      ) : (\n        <ResourceLink to={path}>\n          <IconWrapper>\n            <ContentTypeBadge type={contentType ?? ''} background border={false} />\n          </IconWrapper>\n          <span css={headingStyle}>{name}</span>\n        </ResourceLink>\n      )}\n      <TypeWrapper>\n        {contentTypeName && <ContentTypeName>{contentTypeName}</ContentTypeName>}\n        {access && access === 'teacher' && (\n          <Tooltip tooltip={t('article.access.onlyTeacher')}>\n            <HumanMaleBoard\n              className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n              aria-label={t('article.access.onlyTeacher')}\n            />\n          </Tooltip>\n        )}\n        {showAdditionalResources && contentTypeDescription && (\n          <>\n            {additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Additional\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n            {!additional && (\n              <Tooltip tooltip={contentTypeDescription}>\n                <div>\n                  <Core\n                    className=\"c-icon--20 u-margin-left-tiny c-topic-resource__list__additional-icons\"\n                    aria-label={contentTypeDescription}\n                  />\n                </div>\n              </Tooltip>\n            )}\n          </>\n        )}\n        {heartButton?.(path)}\n      </TypeWrapper>\n    </ListElement>\n  );\n};\n\nexport default ResourceItem;\n"]} */")],
|
|
122
|
-
|
|
150
|
+
}), _jsxs(InlineContainer, {
|
|
151
|
+
children: [_jsx(ResourceLink, {
|
|
152
|
+
to: path,
|
|
153
|
+
"aria-current": active ? 'page' : undefined,
|
|
154
|
+
"aria-describedby": describedBy,
|
|
155
|
+
children: name
|
|
156
|
+
}), active ? _jsx(CurrentSmall, {
|
|
123
157
|
children: t('resource.youAreHere')
|
|
124
|
-
})]
|
|
125
|
-
})]
|
|
126
|
-
}) : _jsxs(ResourceLink, {
|
|
127
|
-
to: path,
|
|
128
|
-
children: [_jsx(IconWrapper, {
|
|
129
|
-
children: _jsx(ContentTypeBadge, {
|
|
130
|
-
type: contentType !== null && contentType !== void 0 ? contentType : '',
|
|
131
|
-
background: true,
|
|
132
|
-
border: false
|
|
133
|
-
})
|
|
134
|
-
}), _jsx("span", {
|
|
135
|
-
css: headingStyle,
|
|
136
|
-
children: name
|
|
158
|
+
}) : undefined]
|
|
137
159
|
})]
|
|
138
160
|
}), _jsxs(TypeWrapper, {
|
|
139
161
|
children: [contentTypeName && _jsx(ContentTypeName, {
|
|
140
162
|
children: contentTypeName
|
|
141
163
|
}), access && access === 'teacher' && _jsx(Tooltip, {
|
|
142
164
|
tooltip: t('article.access.onlyTeacher'),
|
|
143
|
-
children: _jsx(
|
|
144
|
-
|
|
145
|
-
|
|
165
|
+
children: _jsx(IconWrapper, {
|
|
166
|
+
children: _jsx(HumanMaleBoard, {
|
|
167
|
+
id: accessId,
|
|
168
|
+
"aria-label": t('article.access.onlyTeacher')
|
|
169
|
+
})
|
|
146
170
|
})
|
|
147
171
|
}), showAdditionalResources && contentTypeDescription && _jsxs(_Fragment, {
|
|
148
172
|
children: [additional && _jsx(Tooltip, {
|
|
149
173
|
tooltip: contentTypeDescription,
|
|
150
|
-
children: _jsx(
|
|
174
|
+
children: _jsx(IconWrapper, {
|
|
151
175
|
children: _jsx(Additional, {
|
|
152
|
-
|
|
176
|
+
id: additionalId,
|
|
153
177
|
"aria-label": contentTypeDescription
|
|
154
178
|
})
|
|
155
179
|
})
|
|
156
180
|
}), !additional && _jsx(Tooltip, {
|
|
157
181
|
tooltip: contentTypeDescription,
|
|
158
|
-
children: _jsx(
|
|
182
|
+
children: _jsx(IconWrapper, {
|
|
159
183
|
children: _jsx(Core, {
|
|
160
|
-
|
|
184
|
+
id: coreId,
|
|
161
185
|
"aria-label": contentTypeDescription
|
|
162
186
|
})
|
|
163
187
|
})
|