@ndla/ui 35.0.14 → 35.0.17
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/README.md +1 -1
- package/es/Image/Image.js +29 -23
- package/es/MyNdla/Resource/Folder.js +17 -16
- package/es/MyNdla/Resource/FolderMenu.js +74 -0
- package/es/MyNdla/SettingsMenu.js +98 -0
- package/es/MyNdla/index.js +3 -1
- package/es/Resource/BlockResource.js +8 -10
- package/es/Resource/ListResource.js +8 -10
- package/es/index.js +1 -1
- package/es/locale/messages-en.js +3 -1
- package/es/locale/messages-nb.js +3 -1
- package/es/locale/messages-nn.js +3 -1
- package/es/locale/messages-se.js +3 -1
- package/es/locale/messages-sma.js +3 -1
- package/lib/Image/Image.js +29 -23
- package/lib/MyNdla/Resource/Folder.d.ts +4 -3
- package/lib/MyNdla/Resource/Folder.js +17 -16
- package/lib/MyNdla/Resource/FolderMenu.d.ts +16 -0
- package/lib/MyNdla/Resource/FolderMenu.js +81 -0
- package/lib/MyNdla/SettingsMenu.d.ts +15 -0
- package/lib/MyNdla/SettingsMenu.js +96 -0
- package/lib/MyNdla/index.d.ts +3 -1
- package/lib/MyNdla/index.js +14 -0
- package/lib/Resource/BlockResource.js +8 -10
- package/lib/Resource/ListResource.js +8 -10
- package/lib/index.d.ts +1 -1
- package/lib/index.js +6 -0
- 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 +2 -0
- package/lib/locale/messages-nn.js +3 -1
- package/lib/locale/messages-se.d.ts +2 -0
- package/lib/locale/messages-se.js +3 -1
- package/lib/locale/messages-sma.d.ts +2 -0
- package/lib/locale/messages-sma.js +3 -1
- package/package.json +6 -6
- package/src/Image/Image.tsx +16 -2
- package/src/MyNdla/Resource/Folder.tsx +20 -6
- package/src/MyNdla/Resource/FolderMenu.tsx +102 -0
- package/src/MyNdla/SettingsMenu.tsx +97 -0
- package/src/MyNdla/index.ts +3 -1
- package/src/Resource/BlockResource.tsx +3 -2
- package/src/Resource/ListResource.tsx +4 -3
- package/src/index.ts +1 -1
- package/src/locale/messages-en.ts +3 -1
- package/src/locale/messages-nb.ts +3 -1
- package/src/locale/messages-nn.ts +3 -1
- package/src/locale/messages-se.ts +3 -1
- package/src/locale/messages-sma.ts +3 -1
|
@@ -7,12 +7,12 @@ exports["default"] = void 0;
|
|
|
7
7
|
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
var _core = require("@ndla/core");
|
|
10
|
-
var _button = require("@ndla/button");
|
|
11
10
|
var _Image = _interopRequireDefault(require("../Image"));
|
|
12
11
|
var _resourceComponents = require("./resourceComponents");
|
|
13
12
|
var _ContentLoader = _interopRequireDefault(require("../ContentLoader"));
|
|
14
13
|
var _ContentTypeBadge = _interopRequireDefault(require("../ContentTypeBadge"));
|
|
15
14
|
var _ContentType = require("../model/ContentType");
|
|
15
|
+
var _MyNdla = require("../MyNdla");
|
|
16
16
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
17
17
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
18
18
|
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)."; }
|
|
@@ -23,7 +23,7 @@ var ListResourceWrapper = /*#__PURE__*/(0, _base["default"])("div", {
|
|
|
23
23
|
until: _core.breakpoints.mobileWide
|
|
24
24
|
}), "{grid-template-columns:auto 1fr;grid-template-areas:'image topicAndTitle' 'description description' 'tags tags';}cursor:pointer;border:1px solid ", _core.colors.brand.neutral7, ";border-radius:2px;&:hover{box-shadow:1px 1px 6px 2px rgba(9, 55, 101, 0.08);transition-duration:0.2s;", function () {
|
|
25
25
|
return _resourceComponents.ResourceTitleLink;
|
|
26
|
-
}, "{color:", _core.colors.brand.primary, ";text-decoration:underline;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA0BsC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
26
|
+
}, "{color:", _core.colors.brand.primary, ";text-decoration:underline;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA2BsC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
27
27
|
var ImageWrapper = /*#__PURE__*/(0, _base["default"])("div", {
|
|
28
28
|
target: "e18z2zfy4",
|
|
29
29
|
label: "ImageWrapper"
|
|
@@ -31,7 +31,7 @@ var ImageWrapper = /*#__PURE__*/(0, _base["default"])("div", {
|
|
|
31
31
|
return p.imageSize === 'normal' ? '136px' : '56px';
|
|
32
32
|
}, ";", _core.mq.range({
|
|
33
33
|
until: _core.breakpoints.mobileWide
|
|
34
|
-
}), "{width:56px;margin-bottom:0;}overflow:hidden;border-radius:2px;display:flex;margin:", _core.spacing.small, ";align-items:center;justify-content:center;aspect-ratio:4/3;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA4DiD","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
34
|
+
}), "{width:56px;margin-bottom:0;}overflow:hidden;border-radius:2px;display:flex;margin:", _core.spacing.small, ";align-items:center;justify-content:center;aspect-ratio:4/3;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA6DiD","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
35
35
|
var StyledImage = /*#__PURE__*/(0, _base["default"])(_Image["default"], {
|
|
36
36
|
target: "e18z2zfy3",
|
|
37
37
|
label: "StyledImage"
|
|
@@ -41,7 +41,7 @@ var StyledImage = /*#__PURE__*/(0, _base["default"])(_Image["default"], {
|
|
|
41
41
|
} : {
|
|
42
42
|
name: "ie7djk",
|
|
43
43
|
styles: "object-fit:cover;aspect-ratio:4/3",
|
|
44
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA4EiC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */",
|
|
44
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AA6EiC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */",
|
|
45
45
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
46
46
|
});
|
|
47
47
|
var StyledResourceDescription = /*#__PURE__*/(0, _base["default"])("p", {
|
|
@@ -49,19 +49,19 @@ var StyledResourceDescription = /*#__PURE__*/(0, _base["default"])("p", {
|
|
|
49
49
|
label: "StyledResourceDescription"
|
|
50
50
|
})("grid-area:description;line-clamp:2;line-height:1em;height:3.1em;margin:0 ", _core.spacing.small, " ", _core.spacing.small, " 0;", _core.mq.range({
|
|
51
51
|
until: _core.breakpoints.mobileWide
|
|
52
|
-
}), "{margin:0 ", _core.spacing.small, ";}overflow:hidden;", _core.fonts.sizes(16), ";text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAiF0C","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
52
|
+
}), "{margin:0 ", _core.spacing.small, ";}overflow:hidden;", _core.fonts.sizes(16), ";text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAkF0C","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
53
53
|
var TagsandActionMenu = /*#__PURE__*/(0, _base["default"])("div", {
|
|
54
54
|
target: "e18z2zfy1",
|
|
55
55
|
label: "TagsandActionMenu"
|
|
56
56
|
})("grid-area:tags;z-index:1;box-sizing:content-box;display:grid;grid-template-columns:1fr auto auto;align-items:center;align-self:flex-start;justify-items:flex-end;overflow:hidden;", _core.mq.range({
|
|
57
57
|
until: _core.breakpoints.mobileWide
|
|
58
|
-
}), "{min-height:", _core.spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAoGoC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
58
|
+
}), "{min-height:", _core.spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAqGoC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
59
59
|
var TopicAndTitleWrapper = /*#__PURE__*/(0, _base["default"])("div", {
|
|
60
60
|
target: "e18z2zfy0",
|
|
61
61
|
label: "TopicAndTitleWrapper"
|
|
62
62
|
})("grid-area:topicAndTitle;display:flex;margin:", _core.spacing.small, " 0;flex-direction:column;overflow:hidden;margin-right:", _core.spacing.small, ";", _core.mq.range({
|
|
63
63
|
until: _core.breakpoints.mobileWide
|
|
64
|
-
}), "{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAmHuC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React, { useRef } from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuButton, MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <MenuButton align=\"end\" size=\"small\" menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
64
|
+
}), "{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ListResource.tsx"],"names":[],"mappings":"AAoHuC","file":"ListResource.tsx","sourcesContent":["/**\n * Copyright (c) 2022-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport styled from '@emotion/styled';\nimport React from 'react';\nimport { fonts, spacing, colors, breakpoints, mq } from '@ndla/core';\nimport { MenuItemProps } from '@ndla/button';\nimport Image from '../Image';\nimport {\n  CompressedTagList,\n  ResourceImageProps,\n  ResourceTitle,\n  ResourceTitleLink as StyledLink,\n  ResourceTypeList,\n  StyledContentIconWrapper,\n  LoaderProps,\n} from './resourceComponents';\nimport ContentLoader from '../ContentLoader';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { contentTypeMapping } from '../model/ContentType';\nimport { SettingsMenu } from '../MyNdla';\n\nconst ListResourceWrapper = styled.div`\n  flex: 1;\n  display: grid;\n  position: relative;\n  grid-template-columns: auto minmax(50px, 1fr) auto;\n  grid-template-areas:\n    'image  topicAndTitle   tags'\n    'image  description     description';\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    grid-template-columns: auto 1fr;\n    grid-template-areas:\n      'image                topicAndTitle'\n      'description          description'\n      'tags                 tags';\n  }\n\n  cursor: pointer;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 2px;\n\n  &:hover {\n    box-shadow: 1px 1px 6px 2px rgba(9, 55, 101, 0.08);\n    transition-duration: 0.2s;\n    ${() => StyledLink} {\n      color: ${colors.brand.primary};\n      text-decoration: underline;\n    }\n  }\n`;\n\ninterface StyledImageProps {\n  imageSize: 'normal' | 'compact';\n}\n\nconst ImageWrapper = styled.div<StyledImageProps>`\n  grid-area: image;\n  width: ${(p) => (p.imageSize === 'normal' ? '136px' : '56px')};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    width: 56px;\n    margin-bottom: 0;\n  }\n  overflow: hidden;\n  border-radius: 2px;\n  display: flex;\n  margin: ${spacing.small};\n  align-items: center;\n  justify-content: center;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledImage = styled(Image)`\n  object-fit: cover;\n  aspect-ratio: 4/3;\n`;\n\nconst StyledResourceDescription = styled.p`\n  grid-area: description;\n  line-clamp: 2;\n  line-height: 1em;\n  height: 3.1em;\n  margin: 0 ${spacing.small} ${spacing.small} 0;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0 ${spacing.small};\n  }\n  overflow: hidden;\n  ${fonts.sizes(16)};\n  text-overflow: ellipsis;\n  // Unfortunate css needed for multi-line text overflow ellipsis.\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  line-clamp: 2;\n  -webkit-box-orient: vertical;\n`;\n\nconst TagsandActionMenu = styled.div`\n  grid-area: tags;\n  z-index: 1;\n  box-sizing: content-box;\n  display: grid;\n  grid-template-columns: 1fr auto auto;\n  align-items: center;\n  align-self: flex-start;\n  justify-items: flex-end;\n  overflow: hidden;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    min-height: ${spacing.small};\n  }\n`;\n\nconst TopicAndTitleWrapper = styled.div`\n  grid-area: topicAndTitle;\n  display: flex;\n  margin: ${spacing.small} 0;\n  flex-direction: column;\n  overflow: hidden;\n  margin-right: ${spacing.small};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin-bottom: 0;\n  }\n`;\n\ninterface ListResourceImageProps {\n  resourceImage: ResourceImageProps;\n  loading?: boolean;\n  type: 'normal' | 'compact';\n  contentType: string;\n}\n\nconst ListResourceImage = ({ resourceImage, loading, type, contentType }: ListResourceImageProps) => {\n  if (!loading) {\n    if (resourceImage.src === '') {\n      return (\n        <StyledContentIconWrapper contentType={contentType}>\n          <ContentTypeBadge type={contentType} size=\"x-small\" />\n        </StyledContentIconWrapper>\n      );\n    } else {\n      return (\n        <StyledImage alt={resourceImage.alt} src={resourceImage.src} fallbackWidth={type === 'compact' ? 56 : 136} />\n      );\n    }\n  }\n\n  return (\n    <ContentLoader height={'100%'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n      <rect\n        x=\"0\"\n        y=\"0\"\n        rx=\"3\"\n        ry=\"3\"\n        width={type === 'compact' ? '56' : '136'}\n        height={type === 'compact' ? '40' : '96'}\n      />\n    </ContentLoader>\n  );\n};\n\nconst TypeAndTitleLoader = ({ loading, children }: LoaderProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'40px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" rx=\"3\" ry=\"3\" width={'100%'} height={'16'} />\n        <rect x=\"0\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n        <rect x=\"80\" y=\"18\" rx=\"3\" ry=\"3\" width={'70'} height={'16'} />\n      </ContentLoader>\n    );\n  }\n  return <>{children}</>;\n};\n\ninterface ResourceDescriptionProps {\n  description?: string;\n  loading?: boolean;\n}\n\nconst Description = ({ description, loading }: ResourceDescriptionProps) => {\n  if (loading) {\n    return (\n      <ContentLoader height={'20px'} width={'100%'} viewBox={null} preserveAspectRatio=\"none\">\n        <rect x=\"0\" y=\"0\" width=\"100%\" height=\"20\" />\n      </ContentLoader>\n    );\n  }\n  return <StyledResourceDescription>{description}</StyledResourceDescription>;\n};\n\nexport interface ListResourceProps {\n  id: string;\n  link: string;\n  tagLinkPrefix?: string;\n  title: string;\n  resourceImage: ResourceImageProps;\n  headingLevel?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n  resourceTypes: { id: string; name: string }[];\n  tags?: string[];\n  description?: string;\n  menuItems?: MenuItemProps[];\n  isLoading?: boolean;\n  targetBlank?: boolean;\n}\n\nconst ListResource = ({\n  id,\n  link,\n  tagLinkPrefix,\n  title,\n  tags,\n  resourceImage,\n  resourceTypes,\n  headingLevel = 'h2',\n  description,\n  menuItems,\n  isLoading = false,\n  targetBlank,\n}: ListResourceProps) => {\n  const showDescription = description !== undefined;\n  const imageType = showDescription ? 'normal' : 'compact';\n  const firstContentType = resourceTypes?.[0]?.id ?? '';\n  const Title = ResourceTitle.withComponent(headingLevel);\n\n  return (\n    <ListResourceWrapper id={id}>\n      <ImageWrapper imageSize={imageType}>\n        <ListResourceImage\n          resourceImage={resourceImage}\n          loading={isLoading}\n          type={imageType}\n          contentType={contentTypeMapping[firstContentType] ?? contentTypeMapping['default']}\n        />\n      </ImageWrapper>\n      <TopicAndTitleWrapper>\n        <TypeAndTitleLoader loading={isLoading}>\n          <StyledLink to={link} target={targetBlank ? '_blank' : undefined}>\n            <Title title={title}>{title}</Title>\n          </StyledLink>\n          <ResourceTypeList resourceTypes={resourceTypes} />\n        </TypeAndTitleLoader>\n      </TopicAndTitleWrapper>\n      {showDescription && <Description description={description} loading={isLoading} />}\n      <TagsandActionMenu>\n        {tags && tags.length > 0 && <CompressedTagList tagLinkPrefix={tagLinkPrefix} tags={tags} />}\n        {menuItems && menuItems.length > 0 && <SettingsMenu menuItems={menuItems} />}\n      </TagsandActionMenu>\n    </ListResourceWrapper>\n  );\n};\n\nexport default ListResource;\n"]} */"));
|
|
65
65
|
var ListResourceImage = function ListResourceImage(_ref) {
|
|
66
66
|
var resourceImage = _ref.resourceImage,
|
|
67
67
|
loading = _ref.loading,
|
|
@@ -211,9 +211,7 @@ var ListResource = function ListResource(_ref4) {
|
|
|
211
211
|
children: [tags && tags.length > 0 && (0, _jsxRuntime.jsx)(_resourceComponents.CompressedTagList, {
|
|
212
212
|
tagLinkPrefix: tagLinkPrefix,
|
|
213
213
|
tags: tags
|
|
214
|
-
}), menuItems && menuItems.length > 0 && (0, _jsxRuntime.jsx)(
|
|
215
|
-
align: "end",
|
|
216
|
-
size: "small",
|
|
214
|
+
}), menuItems && menuItems.length > 0 && (0, _jsxRuntime.jsx)(_MyNdla.SettingsMenu, {
|
|
217
215
|
menuItems: menuItems
|
|
218
216
|
})]
|
|
219
217
|
})]
|
package/lib/index.d.ts
CHANGED
|
@@ -83,7 +83,7 @@ export { default as ContentPlaceholder } from './ContentPlaceholder';
|
|
|
83
83
|
export { Notion, ConceptNotion } from './Notion';
|
|
84
84
|
export type { NotionVisualElementType, ConceptNotionType } from './Notion';
|
|
85
85
|
export { BannerCard } from './BannerCard';
|
|
86
|
-
export { Folder, FolderInput } from './MyNdla';
|
|
86
|
+
export { Folder, FolderInput, FolderMenu } from './MyNdla';
|
|
87
87
|
export { ListResource, BlockResource } from './Resource';
|
|
88
88
|
export type { ListResourceProps } from './Resource';
|
|
89
89
|
export type { TagType } from './TagSelector';
|
package/lib/index.js
CHANGED
|
@@ -436,6 +436,12 @@ Object.defineProperty(exports, "FolderInput", {
|
|
|
436
436
|
return _MyNdla.FolderInput;
|
|
437
437
|
}
|
|
438
438
|
});
|
|
439
|
+
Object.defineProperty(exports, "FolderMenu", {
|
|
440
|
+
enumerable: true,
|
|
441
|
+
get: function get() {
|
|
442
|
+
return _MyNdla.FolderMenu;
|
|
443
|
+
}
|
|
444
|
+
});
|
|
439
445
|
Object.defineProperty(exports, "Footer", {
|
|
440
446
|
enumerable: true,
|
|
441
447
|
get: function get() {
|
|
@@ -75,6 +75,7 @@ declare const messages: {
|
|
|
75
75
|
resources_plural: string;
|
|
76
76
|
folders: string;
|
|
77
77
|
folders_plural: string;
|
|
78
|
+
settings: string;
|
|
78
79
|
folder: {
|
|
79
80
|
folder: string;
|
|
80
81
|
delete: string;
|
|
@@ -135,6 +136,7 @@ declare const messages: {
|
|
|
135
136
|
examLockInfo: string;
|
|
136
137
|
help: string;
|
|
137
138
|
more: string;
|
|
139
|
+
selectView: string;
|
|
138
140
|
listView: string;
|
|
139
141
|
detailView: string;
|
|
140
142
|
shortView: string;
|
|
@@ -1052,6 +1052,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1052
1052
|
resources_plural: '{{count}} Resources',
|
|
1053
1053
|
folders: '{{count}} Folder',
|
|
1054
1054
|
folders_plural: '{{count}} Folders',
|
|
1055
|
+
settings: 'Settings',
|
|
1055
1056
|
folder: {
|
|
1056
1057
|
folder: 'Folder',
|
|
1057
1058
|
"delete": 'Delete folder',
|
|
@@ -1085,7 +1086,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1085
1086
|
},
|
|
1086
1087
|
button: {
|
|
1087
1088
|
share: 'Share folder',
|
|
1088
|
-
preview: 'Preview
|
|
1089
|
+
preview: 'Preview folder',
|
|
1089
1090
|
unShare: 'Stop sharing',
|
|
1090
1091
|
shareLink: 'Copy link'
|
|
1091
1092
|
}
|
|
@@ -1112,6 +1113,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1112
1113
|
examLockInfo: 'Editing content on Min NDLA is deactivated for pupils during the exam period.',
|
|
1113
1114
|
help: 'Help',
|
|
1114
1115
|
more: 'More options',
|
|
1116
|
+
selectView: 'Select view',
|
|
1115
1117
|
listView: 'List view',
|
|
1116
1118
|
detailView: 'Detailed listview',
|
|
1117
1119
|
shortView: 'Card view',
|
|
@@ -75,6 +75,7 @@ declare const messages: {
|
|
|
75
75
|
resources_plural: string;
|
|
76
76
|
folders: string;
|
|
77
77
|
folders_plural: string;
|
|
78
|
+
settings: string;
|
|
78
79
|
folder: {
|
|
79
80
|
folder: string;
|
|
80
81
|
delete: string;
|
|
@@ -135,6 +136,7 @@ declare const messages: {
|
|
|
135
136
|
examLockInfo: string;
|
|
136
137
|
help: string;
|
|
137
138
|
more: string;
|
|
139
|
+
selectView: string;
|
|
138
140
|
listView: string;
|
|
139
141
|
detailView: string;
|
|
140
142
|
shortView: string;
|
|
@@ -1052,6 +1052,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1052
1052
|
resources_plural: '{{count}} ressurser',
|
|
1053
1053
|
folders: '{{count}} mappe',
|
|
1054
1054
|
folders_plural: '{{count}} mapper',
|
|
1055
|
+
settings: 'Instillinger',
|
|
1055
1056
|
folder: {
|
|
1056
1057
|
folder: 'Mappe',
|
|
1057
1058
|
"delete": 'Slett mappe',
|
|
@@ -1085,7 +1086,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1085
1086
|
},
|
|
1086
1087
|
button: {
|
|
1087
1088
|
share: 'Del mappen',
|
|
1088
|
-
preview: 'Forhåndsvis
|
|
1089
|
+
preview: 'Forhåndsvis mappe',
|
|
1089
1090
|
unShare: 'Avslutt deling',
|
|
1090
1091
|
shareLink: 'Kopier lenke'
|
|
1091
1092
|
}
|
|
@@ -1112,6 +1113,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1112
1113
|
examLockInfo: 'Redigering av innhold på Min NDLA er deaktivert for elever i eksamensperioden.',
|
|
1113
1114
|
help: 'Hjelp',
|
|
1114
1115
|
more: 'Flere valg',
|
|
1116
|
+
selectView: 'Velg visning',
|
|
1115
1117
|
listView: 'Listevisning',
|
|
1116
1118
|
detailView: 'Detaljert listevisning',
|
|
1117
1119
|
shortView: 'Kort visning',
|
|
@@ -75,6 +75,7 @@ declare const messages: {
|
|
|
75
75
|
resources_plural: string;
|
|
76
76
|
folders: string;
|
|
77
77
|
folders_plural: string;
|
|
78
|
+
settings: string;
|
|
78
79
|
folder: {
|
|
79
80
|
folder: string;
|
|
80
81
|
delete: string;
|
|
@@ -135,6 +136,7 @@ declare const messages: {
|
|
|
135
136
|
examLockInfo: string;
|
|
136
137
|
help: string;
|
|
137
138
|
more: string;
|
|
139
|
+
selectView: string;
|
|
138
140
|
listView: string;
|
|
139
141
|
detailView: string;
|
|
140
142
|
shortView: string;
|
|
@@ -1052,6 +1052,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1052
1052
|
resources_plural: '{{count}} ressursar',
|
|
1053
1053
|
folders: '{{count}} mappe',
|
|
1054
1054
|
folders_plural: '{{count}} mapper',
|
|
1055
|
+
settings: 'Instillinger',
|
|
1055
1056
|
folder: {
|
|
1056
1057
|
folder: 'Mappe',
|
|
1057
1058
|
"delete": 'Slett mappe',
|
|
@@ -1085,7 +1086,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1085
1086
|
},
|
|
1086
1087
|
button: {
|
|
1087
1088
|
share: 'Del mappa',
|
|
1088
|
-
preview: 'Førehandsvis
|
|
1089
|
+
preview: 'Førehandsvis mappe',
|
|
1089
1090
|
unShare: 'Avslutt deling',
|
|
1090
1091
|
shareLink: 'Kopier lenke'
|
|
1091
1092
|
}
|
|
@@ -1112,6 +1113,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1112
1113
|
examLockInfo: 'Redigering av innhald på Min NDLA er deaktivert for elevar i eksamensperioden.',
|
|
1113
1114
|
help: 'Hjelp',
|
|
1114
1115
|
more: 'Fleire val',
|
|
1116
|
+
selectView: 'Velg visning',
|
|
1115
1117
|
listView: 'Listevisning',
|
|
1116
1118
|
detailView: 'Detaljert listevisning',
|
|
1117
1119
|
shortView: 'Kortvisning',
|
|
@@ -75,6 +75,7 @@ declare const messages: {
|
|
|
75
75
|
resources_plural: string;
|
|
76
76
|
folders: string;
|
|
77
77
|
folders_plural: string;
|
|
78
|
+
settings: string;
|
|
78
79
|
folder: {
|
|
79
80
|
folder: string;
|
|
80
81
|
delete: string;
|
|
@@ -135,6 +136,7 @@ declare const messages: {
|
|
|
135
136
|
examLockInfo: string;
|
|
136
137
|
help: string;
|
|
137
138
|
more: string;
|
|
139
|
+
selectView: string;
|
|
138
140
|
listView: string;
|
|
139
141
|
detailView: string;
|
|
140
142
|
shortView: string;
|
|
@@ -1052,6 +1052,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1052
1052
|
resources_plural: '{{count}} resurssat',
|
|
1053
1053
|
folders: '{{count}} máhpat',
|
|
1054
1054
|
folders_plural: '{{count}} mapper',
|
|
1055
|
+
settings: 'Instillinger',
|
|
1055
1056
|
folder: {
|
|
1056
1057
|
folder: 'Máhppa',
|
|
1057
1058
|
"delete": 'Sihko máhpa',
|
|
@@ -1085,7 +1086,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1085
1086
|
},
|
|
1086
1087
|
button: {
|
|
1087
1088
|
share: 'Del mappen',
|
|
1088
|
-
preview: 'Forhåndsvis
|
|
1089
|
+
preview: 'Forhåndsvis mappe',
|
|
1089
1090
|
unShare: 'Avslutt deling',
|
|
1090
1091
|
shareLink: 'Kopier lenke'
|
|
1091
1092
|
}
|
|
@@ -1112,6 +1113,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1112
1113
|
examLockInfo: 'Mu NDLA sisdoalu redigeren ii leat doaimmas ohppiide eksámenáigodagas.',
|
|
1113
1114
|
help: 'Veahkki',
|
|
1114
1115
|
more: 'Eanet válljejumit',
|
|
1116
|
+
selectView: 'Velg visning',
|
|
1115
1117
|
listView: 'Oppalašlistu',
|
|
1116
1118
|
detailView: 'Bienalaš oppalašlistu',
|
|
1117
1119
|
shortView: 'Oanehis listu',
|
|
@@ -75,6 +75,7 @@ declare const messages: {
|
|
|
75
75
|
resources_plural: string;
|
|
76
76
|
folders: string;
|
|
77
77
|
folders_plural: string;
|
|
78
|
+
settings: string;
|
|
78
79
|
folder: {
|
|
79
80
|
folder: string;
|
|
80
81
|
delete: string;
|
|
@@ -135,6 +136,7 @@ declare const messages: {
|
|
|
135
136
|
examLockInfo: string;
|
|
136
137
|
help: string;
|
|
137
138
|
more: string;
|
|
139
|
+
selectView: string;
|
|
138
140
|
listView: string;
|
|
139
141
|
detailView: string;
|
|
140
142
|
shortView: string;
|
|
@@ -1052,6 +1052,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1052
1052
|
resources_plural: '{{count}} ressurser',
|
|
1053
1053
|
folders: '{{count}} mappe',
|
|
1054
1054
|
folders_plural: '{{count}} mapper',
|
|
1055
|
+
settings: 'Instillinger',
|
|
1055
1056
|
folder: {
|
|
1056
1057
|
folder: 'Mappe',
|
|
1057
1058
|
"delete": 'Slett mappe',
|
|
@@ -1085,7 +1086,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1085
1086
|
},
|
|
1086
1087
|
button: {
|
|
1087
1088
|
share: 'Del mappen',
|
|
1088
|
-
preview: 'Forhåndsvis
|
|
1089
|
+
preview: 'Forhåndsvis mappe',
|
|
1089
1090
|
unShare: 'Avslutt deling',
|
|
1090
1091
|
shareLink: 'Kopier lenke'
|
|
1091
1092
|
}
|
|
@@ -1112,6 +1113,7 @@ var messages = _objectSpread(_objectSpread({
|
|
|
1112
1113
|
examLockInfo: 'Redigering av innhold på Min NDLA er deaktivert for elever i eksamensperioden.',
|
|
1113
1114
|
help: 'Hjelp',
|
|
1114
1115
|
more: 'Flere valg',
|
|
1116
|
+
selectView: 'Velg visning',
|
|
1115
1117
|
listView: 'Listevisning',
|
|
1116
1118
|
detailView: 'Detaljert listevisning',
|
|
1117
1119
|
shortView: 'Kort visning',
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ndla/ui",
|
|
3
|
-
"version": "35.0.
|
|
3
|
+
"version": "35.0.17",
|
|
4
4
|
"description": "UI component library for NDLA.",
|
|
5
5
|
"license": "GPL-3.0",
|
|
6
6
|
"main": "lib/index.js",
|
|
@@ -32,16 +32,16 @@
|
|
|
32
32
|
],
|
|
33
33
|
"dependencies": {
|
|
34
34
|
"@ndla/article-scripts": "^3.0.17",
|
|
35
|
-
"@ndla/button": "^10.0.
|
|
35
|
+
"@ndla/button": "^10.0.8",
|
|
36
36
|
"@ndla/carousel": "^3.0.9",
|
|
37
37
|
"@ndla/core": "^3.1.3",
|
|
38
|
-
"@ndla/forms": "^4.2.
|
|
38
|
+
"@ndla/forms": "^4.2.17",
|
|
39
39
|
"@ndla/hooks": "^2.0.4",
|
|
40
40
|
"@ndla/icons": "^2.2.9",
|
|
41
41
|
"@ndla/licenses": "^7.0.4",
|
|
42
42
|
"@ndla/modal": "^2.2.13",
|
|
43
|
-
"@ndla/notion": "^4.2.
|
|
44
|
-
"@ndla/safelink": "^4.0.
|
|
43
|
+
"@ndla/notion": "^4.2.14",
|
|
44
|
+
"@ndla/safelink": "^4.0.18",
|
|
45
45
|
"@ndla/switch": "^1.0.8",
|
|
46
46
|
"@ndla/tabs": "^2.1.15",
|
|
47
47
|
"@ndla/tooltip": "^4.0.16",
|
|
@@ -87,5 +87,5 @@
|
|
|
87
87
|
"publishConfig": {
|
|
88
88
|
"access": "public"
|
|
89
89
|
},
|
|
90
|
-
"gitHead": "
|
|
90
|
+
"gitHead": "2dd0bb09279ea459d068a06c4196ce521bc6fd2a"
|
|
91
91
|
}
|