@ndla/ui 50.4.0 → 50.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Footer/Footer.js +9 -9
- package/es/Footer/FooterLinks.js +8 -8
- package/es/FrontpageArticle/FrontpageArticle.js +2 -2
- package/es/LearningPaths/LearningPathInformation.js +4 -4
- package/es/LearningPaths/LearningPathLastStepNavigation.js +5 -5
- package/es/LearningPaths/LearningPathMenuAside.js +5 -5
- package/es/LearningPaths/LearningPathMenuContent.js +7 -7
- package/es/MediaList/MediaList.js +94 -70
- package/es/NDLAFilm/MovieGrid.js +3 -3
- package/es/NDLAFilm/filmStyles.js +4 -4
- package/es/Resource/BlockResource.js +23 -10
- package/es/Resource/ListResource.js +16 -10
- package/es/Resource/resourceComponents.js +19 -11
- package/es/Subject/SubjectHeader.js +5 -5
- package/es/all.css +1 -1
- package/es/locale/messages-en.js +6 -3
- package/es/locale/messages-nb.js +5 -2
- package/es/locale/messages-nn.js +5 -2
- package/es/locale/messages-se.js +5 -2
- package/es/locale/messages-sma.js +5 -2
- package/lib/Footer/Footer.js +9 -9
- package/lib/Footer/FooterLinks.js +7 -7
- package/lib/FrontpageArticle/FrontpageArticle.js +1 -1
- package/lib/LearningPaths/LearningPathInformation.js +4 -4
- package/lib/LearningPaths/LearningPathLastStepNavigation.js +4 -4
- package/lib/LearningPaths/LearningPathMenuAside.js +5 -5
- package/lib/LearningPaths/LearningPathMenuContent.js +7 -7
- package/lib/MediaList/MediaList.d.ts +4 -18
- package/lib/MediaList/MediaList.js +94 -73
- package/lib/NDLAFilm/MovieGrid.js +2 -2
- package/lib/NDLAFilm/filmStyles.js +3 -3
- package/lib/Resource/BlockResource.d.ts +1 -2
- package/lib/Resource/BlockResource.js +22 -9
- package/lib/Resource/ListResource.js +15 -9
- package/lib/Resource/resourceComponents.js +19 -11
- package/lib/Subject/SubjectHeader.js +4 -4
- package/lib/all.css +1 -1
- package/lib/locale/messages-en.d.ts +3 -0
- package/lib/locale/messages-en.js +6 -3
- package/lib/locale/messages-nb.d.ts +3 -0
- package/lib/locale/messages-nb.js +5 -2
- package/lib/locale/messages-nn.d.ts +3 -0
- package/lib/locale/messages-nn.js +5 -2
- package/lib/locale/messages-se.d.ts +3 -0
- package/lib/locale/messages-se.js +5 -2
- package/lib/locale/messages-sma.d.ts +3 -0
- package/lib/locale/messages-sma.js +5 -2
- package/package.json +17 -17
- package/src/Footer/Footer.tsx +7 -9
- package/src/Footer/FooterLinks.tsx +1 -1
- package/src/FrontpageArticle/FrontpageArticle.tsx +3 -3
- package/src/LearningPaths/LearningPathInformation.tsx +1 -1
- package/src/LearningPaths/LearningPathLastStepNavigation.tsx +2 -2
- package/src/LearningPaths/LearningPathMenuAside.tsx +1 -1
- package/src/LearningPaths/LearningPathMenuContent.tsx +2 -2
- package/src/Logo/component.logo.scss +3 -0
- package/src/MediaList/MediaList.tsx +93 -50
- package/src/NDLAFilm/MovieGrid.tsx +3 -3
- package/src/NDLAFilm/filmStyles.ts +3 -3
- package/src/Resource/BlockResource.stories.tsx +0 -3
- package/src/Resource/BlockResource.tsx +9 -8
- package/src/Resource/ListResource.stories.tsx +0 -3
- package/src/Resource/ListResource.tsx +11 -8
- package/src/Resource/resourceComponents.tsx +0 -2
- package/src/Subject/SubjectHeader.tsx +3 -3
- package/src/locale/messages-en.ts +4 -1
- package/src/locale/messages-nb.ts +3 -0
- package/src/locale/messages-nn.ts +3 -0
- package/src/locale/messages-se.ts +3 -0
- package/src/locale/messages-sma.ts +3 -0
- package/src/main.scss +0 -2
- package/src/MediaList/component.medialist.scss +0 -93
- package/src/global/components/component.logo.scss +0 -5
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
+
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)."; }
|
|
2
3
|
/**
|
|
3
4
|
* Copyright (c) 2016-present, NDLA.
|
|
4
5
|
*
|
|
@@ -7,51 +8,56 @@ import _styled from "@emotion/styled/base";
|
|
|
7
8
|
*
|
|
8
9
|
*/
|
|
9
10
|
|
|
10
|
-
import
|
|
11
|
-
import { breakpoints, colors, mq, spacing } from '@ndla/core';
|
|
11
|
+
import { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
|
|
12
12
|
import { Launch } from '@ndla/icons/common';
|
|
13
13
|
import { getLicenseByAbbreviation, getResourceTypeNamespace, isCreativeCommonsLicense, metaTypes } from '@ndla/licenses';
|
|
14
14
|
import { LicenseDescription } from '@ndla/notion';
|
|
15
|
+
import SafeLink from '@ndla/safelink';
|
|
16
|
+
import { Text } from '@ndla/typography';
|
|
15
17
|
import { uuid } from '@ndla/util';
|
|
16
18
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
17
19
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
18
20
|
import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
});
|
|
23
|
-
const cClasses = new BEMHelper({
|
|
24
|
-
name: 'medialist',
|
|
25
|
-
prefix: 'c-'
|
|
26
|
-
});
|
|
21
|
+
const StyledMediaList = /*#__PURE__*/_styled("ul", {
|
|
22
|
+
target: "er7hlkd8",
|
|
23
|
+
label: "StyledMediaList"
|
|
24
|
+
})("padding-left:0;display:flex;flex-direction:column;margin:", spacing.normal, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAwBiC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
27
25
|
export const MediaList = _ref => {
|
|
28
26
|
let {
|
|
29
|
-
children
|
|
27
|
+
children,
|
|
28
|
+
...rest
|
|
30
29
|
} = _ref;
|
|
31
|
-
return _jsx(
|
|
32
|
-
...
|
|
30
|
+
return _jsx(StyledMediaList, {
|
|
31
|
+
...rest,
|
|
33
32
|
children: children
|
|
34
33
|
});
|
|
35
34
|
};
|
|
35
|
+
const StyledMediaListItem = /*#__PURE__*/_styled("li", {
|
|
36
|
+
target: "er7hlkd7",
|
|
37
|
+
label: "StyledMediaListItem"
|
|
38
|
+
})("margin-bottom:", spacing.small, ";padding:", spacing.small, " 0;border-bottom:1px solid ", colors.brand.tertiary, ";", mq.range({
|
|
39
|
+
from: breakpoints.tablet
|
|
40
|
+
}), "{display:flex;flex-direction:row;}&:last-of-type{border-bottom:none;}img{width:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAmCqC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
36
41
|
export const MediaListItem = _ref2 => {
|
|
37
42
|
let {
|
|
38
|
-
children
|
|
43
|
+
children,
|
|
44
|
+
...rest
|
|
39
45
|
} = _ref2;
|
|
40
|
-
return _jsx(
|
|
41
|
-
...
|
|
46
|
+
return _jsx(StyledMediaListItem, {
|
|
47
|
+
...rest,
|
|
42
48
|
children: children
|
|
43
49
|
});
|
|
44
50
|
};
|
|
45
51
|
const ImageWrapper = /*#__PURE__*/_styled("div", {
|
|
46
|
-
target: "
|
|
52
|
+
target: "er7hlkd6",
|
|
47
53
|
label: "ImageWrapper"
|
|
48
54
|
})("position:relative;align-self:flex-start;margin-right:", spacing.small, ";", mq.range({
|
|
49
55
|
from: breakpoints.tablet
|
|
50
|
-
}), "{width:25%;}a{display:block;box-shadow:none;}&:hover,&:focus-visible{[data-open-indicator]{background-color:", colors.brand.dark, ";padding:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAmD+B","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ReactNode } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport { uuid } from '@ndla/util';\n\nconst oClasses = new BEMHelper({\n  name: 'media',\n  prefix: 'o-',\n});\n\nconst cClasses = new BEMHelper({\n  name: 'medialist',\n  prefix: 'c-',\n});\n\ninterface MediaListProps {\n  children: ReactNode;\n}\n\nexport const MediaList = ({ children }: MediaListProps) => <ul {...cClasses()}>{children}</ul>;\n\ninterface MediaListItemProps {\n  children: ReactNode;\n}\nexport const MediaListItem = ({ children }: MediaListItemProps) => (\n  <li {...oClasses(undefined, undefined, cClasses('item').className)}>{children}</li>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListCCLinkProps {\n  children: ReactNode;\n  url: string;\n}\nexport const MediaListCCLink = ({ children, url }: MediaListCCLinkProps) => (\n  <a rel=\"noopener noreferrer license\" href={url}>\n    {children}\n  </a>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        ...oClasses('body', undefined, cClasses('body').className),\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {\n        ...oClasses('body', undefined, cClasses('body').className),\n      };\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <div {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? <h3 className=\"c-medialist__title\">{title} </h3> : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <MediaListCCLink url={license.url}>{license.linkText}</MediaListCCLink>\n      {children}\n    </div>\n  );\n};\n\ninterface MediaListItemActionsProps {\n  children: ReactNode;\n}\nexport const MediaListItemActions = ({ children }: MediaListItemActionsProps) => (\n  <div {...cClasses('actions')}>{children}</div>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <a href={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </a>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    // eslint-disable-next-line react/no-unknown-property\n    <ul {...cClasses('actions')} property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <li key={uuid()} className=\"c-medialist__meta-item\">\n          <ItemText item={item} />\n        </li>\n      ))}\n    </ul>\n  );\n};\n"]} */"));
|
|
56
|
+
}), "{width:25%;}a{display:block;box-shadow:none;}&:hover,&:focus-visible{[data-open-indicator]{background-color:", colors.brand.dark, ";padding:", spacing.xsmall, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AA6D+B","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
51
57
|
const OpenIndicator = /*#__PURE__*/_styled("div", {
|
|
52
|
-
target: "
|
|
58
|
+
target: "er7hlkd5",
|
|
53
59
|
label: "OpenIndicator"
|
|
54
|
-
})("position:absolute;display:flex;align-items:center;right:", spacing.xsmall, ";bottom:", spacing.xsmall, ";padding:", spacing.xxsmall, ";transition:all 50ms ease-in;background-color:", colors.brand.primary, ";border-radius:100%;pointer-events:none;z-index:1;svg{color:", colors.white, ";width:", spacing.normal, ";height:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAuEgC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ReactNode } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport { uuid } from '@ndla/util';\n\nconst oClasses = new BEMHelper({\n  name: 'media',\n  prefix: 'o-',\n});\n\nconst cClasses = new BEMHelper({\n  name: 'medialist',\n  prefix: 'c-',\n});\n\ninterface MediaListProps {\n  children: ReactNode;\n}\n\nexport const MediaList = ({ children }: MediaListProps) => <ul {...cClasses()}>{children}</ul>;\n\ninterface MediaListItemProps {\n  children: ReactNode;\n}\nexport const MediaListItem = ({ children }: MediaListItemProps) => (\n  <li {...oClasses(undefined, undefined, cClasses('item').className)}>{children}</li>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListCCLinkProps {\n  children: ReactNode;\n  url: string;\n}\nexport const MediaListCCLink = ({ children, url }: MediaListCCLinkProps) => (\n  <a rel=\"noopener noreferrer license\" href={url}>\n    {children}\n  </a>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        ...oClasses('body', undefined, cClasses('body').className),\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {\n        ...oClasses('body', undefined, cClasses('body').className),\n      };\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <div {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? <h3 className=\"c-medialist__title\">{title} </h3> : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <MediaListCCLink url={license.url}>{license.linkText}</MediaListCCLink>\n      {children}\n    </div>\n  );\n};\n\ninterface MediaListItemActionsProps {\n  children: ReactNode;\n}\nexport const MediaListItemActions = ({ children }: MediaListItemActionsProps) => (\n  <div {...cClasses('actions')}>{children}</div>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <a href={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </a>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    // eslint-disable-next-line react/no-unknown-property\n    <ul {...cClasses('actions')} property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <li key={uuid()} className=\"c-medialist__meta-item\">\n          <ItemText item={item} />\n        </li>\n      ))}\n    </ul>\n  );\n};\n"]} */"));
|
|
60
|
+
})("position:absolute;display:flex;align-items:center;right:", spacing.xsmall, ";bottom:", spacing.xsmall, ";padding:", spacing.xxsmall, ";transition:all 50ms ease-in;background-color:", colors.brand.primary, ";border-radius:100%;pointer-events:none;z-index:1;svg{color:", colors.white, ";width:", spacing.normal, ";height:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAiFgC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
55
61
|
export const MediaListItemImage = _ref3 => {
|
|
56
62
|
let {
|
|
57
63
|
children,
|
|
@@ -64,18 +70,19 @@ export const MediaListItemImage = _ref3 => {
|
|
|
64
70
|
}), children]
|
|
65
71
|
});
|
|
66
72
|
};
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
href: url,
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
export const MediaListItemBody = _ref5 => {
|
|
73
|
+
const StyledMediaListItemBody = /*#__PURE__*/_styled("div", {
|
|
74
|
+
target: "er7hlkd4",
|
|
75
|
+
label: "StyledMediaListItemBody"
|
|
76
|
+
})(fonts.size.text.metaText.small, ";", mq.range({
|
|
77
|
+
from: breakpoints.tablet
|
|
78
|
+
}), "{max-width:70%;}", mq.range({
|
|
79
|
+
from: breakpoints.desktop
|
|
80
|
+
}), "{max-width:75%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AA2H0C","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
81
|
+
const BodyTitle = /*#__PURE__*/_styled(Text, {
|
|
82
|
+
target: "er7hlkd3",
|
|
83
|
+
label: "BodyTitle"
|
|
84
|
+
})("color:", colors.brand.primary, ";font-weight:", fonts.weight.bold, ";margin-bottom:", spacing.xsmall, ";+p{margin-top:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAqI8B","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
85
|
+
export const MediaListItemBody = _ref4 => {
|
|
79
86
|
let {
|
|
80
87
|
children,
|
|
81
88
|
license: licenseAbbreviation,
|
|
@@ -85,18 +92,15 @@ export const MediaListItemBody = _ref5 => {
|
|
|
85
92
|
resourceUrl = '',
|
|
86
93
|
// defaults to current page
|
|
87
94
|
resourceType
|
|
88
|
-
} =
|
|
95
|
+
} = _ref4;
|
|
89
96
|
const license = getLicenseByAbbreviation(licenseAbbreviation, locale);
|
|
90
97
|
const containerProps = isCreativeCommonsLicense(license.rights) ? {
|
|
91
|
-
...oClasses('body', undefined, cClasses('body').className),
|
|
92
98
|
'xmlns:cc': 'https://creativecommons.org/ns#',
|
|
93
99
|
'xmlns:dct': 'http://purl.org/dc/terms/',
|
|
94
100
|
about: resourceUrl
|
|
95
|
-
} : {
|
|
96
|
-
...oClasses('body', undefined, cClasses('body').className)
|
|
97
|
-
};
|
|
101
|
+
} : {};
|
|
98
102
|
const metaResourceType = getResourceTypeNamespace(resourceType);
|
|
99
|
-
return _jsxs(
|
|
103
|
+
return _jsxs(StyledMediaListItemBody, {
|
|
100
104
|
...containerProps,
|
|
101
105
|
children: [metaResourceType && _jsx("span", {
|
|
102
106
|
rel: "dct:type",
|
|
@@ -104,38 +108,47 @@ export const MediaListItemBody = _ref5 => {
|
|
|
104
108
|
style: {
|
|
105
109
|
display: 'none'
|
|
106
110
|
}
|
|
107
|
-
}), title ?
|
|
108
|
-
|
|
109
|
-
|
|
111
|
+
}), title ? _jsx(BodyTitle, {
|
|
112
|
+
element: "h3",
|
|
113
|
+
margin: "none",
|
|
114
|
+
textStyle: "meta-text-medium",
|
|
115
|
+
children: title
|
|
110
116
|
}) : null, _jsx(LicenseDescription, {
|
|
111
117
|
locale: locale,
|
|
112
118
|
messages: messages,
|
|
113
119
|
licenseRights: license.rights,
|
|
114
120
|
highlightCC: true
|
|
115
|
-
}), _jsx(
|
|
116
|
-
|
|
121
|
+
}), _jsx(SafeLink, {
|
|
122
|
+
rel: "noopener noreferrer license",
|
|
123
|
+
target: "_blank",
|
|
124
|
+
to: license.url,
|
|
117
125
|
children: license.linkText
|
|
118
126
|
}), children]
|
|
119
127
|
});
|
|
120
128
|
};
|
|
121
|
-
|
|
129
|
+
const StyledMediaListItemActions = /*#__PURE__*/_styled("div", {
|
|
130
|
+
target: "er7hlkd2",
|
|
131
|
+
label: "StyledMediaListItemActions"
|
|
132
|
+
})("margin:", spacing.small, " 0;list-style:none;width:100%;button,a{margin:0 ", spacing.small, " ", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAoL6C","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
133
|
+
export const MediaListItemActions = _ref5 => {
|
|
122
134
|
let {
|
|
123
|
-
children
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
135
|
+
children,
|
|
136
|
+
...rest
|
|
137
|
+
} = _ref5;
|
|
138
|
+
return _jsx(StyledMediaListItemActions, {
|
|
139
|
+
...rest,
|
|
127
140
|
children: children
|
|
128
141
|
});
|
|
129
142
|
};
|
|
130
143
|
const isLink = text => text.startsWith('http') || text.startsWith('https');
|
|
131
|
-
export const HandleLink =
|
|
144
|
+
export const HandleLink = _ref6 => {
|
|
132
145
|
let {
|
|
133
146
|
text,
|
|
134
147
|
children
|
|
135
|
-
} =
|
|
148
|
+
} = _ref6;
|
|
136
149
|
if (isLink(text)) {
|
|
137
|
-
return _jsx(
|
|
138
|
-
|
|
150
|
+
return _jsx(SafeLink, {
|
|
151
|
+
to: text,
|
|
139
152
|
target: "_blank",
|
|
140
153
|
rel: "noopener noreferrer",
|
|
141
154
|
children: children
|
|
@@ -149,10 +162,10 @@ const attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes
|
|
|
149
162
|
function isOtherWithoutDescription(item) {
|
|
150
163
|
return item.metaType === metaTypes.otherWithoutDescription;
|
|
151
164
|
}
|
|
152
|
-
const ItemText =
|
|
165
|
+
const ItemText = _ref7 => {
|
|
153
166
|
let {
|
|
154
167
|
item
|
|
155
|
-
} =
|
|
168
|
+
} = _ref7;
|
|
156
169
|
if (isOtherWithoutDescription(item)) {
|
|
157
170
|
return _jsx(_Fragment, {
|
|
158
171
|
children: item.label
|
|
@@ -169,24 +182,35 @@ function isAttributionItem(item) {
|
|
|
169
182
|
if (isOtherWithoutDescription(item)) return false;
|
|
170
183
|
return attributionTypes.some(type => type === item.metaType);
|
|
171
184
|
}
|
|
172
|
-
|
|
185
|
+
const StyledMediaListItemMeta = /*#__PURE__*/_styled("ul", {
|
|
186
|
+
target: "er7hlkd1",
|
|
187
|
+
label: "StyledMediaListItemMeta"
|
|
188
|
+
})("margin:", spacing.small, " 0;list-style:none;width:100%;button,a{margin:0 ", spacing.small, " ", spacing.small, " 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AA4PyC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */"));
|
|
189
|
+
const StyledMediaListMetaItem = /*#__PURE__*/_styled("li", {
|
|
190
|
+
target: "er7hlkd0",
|
|
191
|
+
label: "StyledMediaListMetaItem"
|
|
192
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
193
|
+
name: "1xclg2i",
|
|
194
|
+
styles: "margin:0;padding:0"
|
|
195
|
+
} : {
|
|
196
|
+
name: "1xclg2i",
|
|
197
|
+
styles: "margin:0;padding:0",
|
|
198
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MediaList.tsx"],"names":[],"mappings":"AAsQyC","file":"MediaList.tsx","sourcesContent":["/**\n * Copyright (c) 2016-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 { ComponentProps, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { Launch } from '@ndla/icons/common';\nimport {\n  getLicenseByAbbreviation,\n  getResourceTypeNamespace,\n  isCreativeCommonsLicense,\n  metaTypes,\n} from '@ndla/licenses';\nimport type { MetaType } from '@ndla/licenses';\nimport { LicenseDescription } from '@ndla/notion';\nimport SafeLink from '@ndla/safelink';\nimport { Heading, Text } from '@ndla/typography';\nimport { uuid } from '@ndla/util';\n\nconst StyledMediaList = styled.ul`\n  padding-left: 0;\n  display: flex;\n  flex-direction: column;\n  margin: ${spacing.normal} 0;\n`;\n\nexport const MediaList = ({ children, ...rest }: ComponentProps<'ul'>) => (\n  <StyledMediaList {...rest}>{children}</StyledMediaList>\n);\n\nconst StyledMediaListItem = styled.li`\n  margin-bottom: ${spacing.small};\n  padding: ${spacing.small} 0;\n  border-bottom: 1px solid ${colors.brand.tertiary};\n  ${mq.range({ from: breakpoints.tablet })} {\n    display: flex;\n    flex-direction: row;\n  }\n\n  &:last-of-type {\n    border-bottom: none;\n  }\n  img {\n    width: 100%;\n  }\n`;\n\nexport const MediaListItem = ({ children, ...rest }: ComponentProps<'li'>) => (\n  <StyledMediaListItem {...rest}>{children}</StyledMediaListItem>\n);\n\ninterface MediaListItemImageProps {\n  children: ReactNode;\n  canOpen?: boolean;\n}\n\nconst ImageWrapper = styled.div`\n  position: relative;\n  align-self: flex-start;\n  margin-right: ${spacing.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 25%;\n  }\n  a {\n    display: block;\n    box-shadow: none;\n  }\n  &:hover,\n  &:focus-visible {\n    [data-open-indicator] {\n      background-color: ${colors.brand.dark};\n      padding: ${spacing.xsmall};\n    }\n  }\n`;\n\nconst OpenIndicator = styled.div`\n  position: absolute;\n  display: flex;\n  align-items: center;\n  right: ${spacing.xsmall};\n  bottom: ${spacing.xsmall};\n  padding: ${spacing.xxsmall};\n  transition: all 50ms ease-in;\n  background-color: ${colors.brand.primary};\n  border-radius: 100%;\n  pointer-events: none;\n  z-index: 1;\n  svg {\n    color: ${colors.white};\n    width: ${spacing.normal};\n    height: ${spacing.normal};\n  }\n`;\n\nexport const MediaListItemImage = ({ children, canOpen }: MediaListItemImageProps) => (\n  <ImageWrapper>\n    {canOpen && (\n      <OpenIndicator data-open-indicator>\n        <Launch />\n      </OpenIndicator>\n    )}\n    {children}\n  </ImageWrapper>\n);\n\ninterface MediaListItemBodyProps {\n  children: ReactNode;\n  license: string;\n  locale: string;\n  resourceUrl?: string;\n  resourceType?: 'video' | 'image' | 'audio' | 'text' | 'h5p' | 'podcast';\n  messages?: {\n    modelPremission?: string;\n  };\n  title?: string;\n}\n\nconst StyledMediaListItemBody = styled.div`\n  ${fonts.size.text.metaText.small};\n  ${mq.range({ from: breakpoints.tablet })} {\n    max-width: 70%;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    max-width: 75%;\n  }\n`;\n\nconst BodyTitle = styled(Text)`\n  color: ${colors.brand.primary};\n  font-weight: ${fonts.weight.bold};\n  margin-bottom: ${spacing.xsmall};\n  + p {\n    margin-top: ${spacing.small};\n  }\n`;\n\nexport const MediaListItemBody = ({\n  children,\n  license: licenseAbbreviation,\n  messages,\n  title,\n  locale,\n  resourceUrl = '', // defaults to current page\n  resourceType,\n}: MediaListItemBodyProps) => {\n  const license = getLicenseByAbbreviation(licenseAbbreviation, locale);\n  const containerProps = isCreativeCommonsLicense(license.rights)\n    ? {\n        'xmlns:cc': 'https://creativecommons.org/ns#',\n        'xmlns:dct': 'http://purl.org/dc/terms/',\n        about: resourceUrl,\n      }\n    : {};\n\n  const metaResourceType = getResourceTypeNamespace(resourceType);\n\n  return (\n    <StyledMediaListItemBody {...containerProps}>\n      {/* @ts-ignore */}\n      {metaResourceType && <span rel=\"dct:type\" href={metaResourceType} style={{ display: 'none' }} />}\n      {title ? (\n        <BodyTitle element=\"h3\" margin=\"none\" textStyle=\"meta-text-medium\">\n          {title}\n        </BodyTitle>\n      ) : null}\n      <LicenseDescription locale={locale} messages={messages} licenseRights={license.rights} highlightCC />\n      <SafeLink rel=\"noopener noreferrer license\" target=\"_blank\" to={license.url}>\n        {license.linkText}\n      </SafeLink>\n      {children}\n    </StyledMediaListItemBody>\n  );\n};\n\nconst StyledMediaListItemActions = styled.div`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nexport const MediaListItemActions = ({ children, ...rest }: ComponentProps<'div'>) => (\n  <StyledMediaListItemActions {...rest}>{children}</StyledMediaListItemActions>\n);\n\nconst isLink = (text: string) => text.startsWith('http') || text.startsWith('https');\n\ninterface HandleLinkProps {\n  text: string;\n  children: ReactNode;\n}\n\nexport const HandleLink = ({ text, children }: HandleLinkProps) => {\n  if (isLink(text)) {\n    return (\n      <SafeLink to={text} target=\"_blank\" rel=\"noopener noreferrer\">\n        {children}\n      </SafeLink>\n    );\n  }\n  return <span>{children}</span>;\n};\n\nconst attributionTypes = [metaTypes.author, metaTypes.copyrightHolder, metaTypes.contributor];\n\nexport type ItemType = ItemTypeWithDescription | DescriptionLessItemType;\n\ninterface ItemTypeWithDescription {\n  label: string;\n  description: string;\n  metaType: Omit<MetaType, 'otherWithoutDescription'>;\n}\n\ninterface DescriptionLessItemType {\n  label: string;\n  metaType: 'otherWithoutDescription';\n}\n\nfunction isOtherWithoutDescription(item: ItemType): item is DescriptionLessItemType {\n  return item.metaType === metaTypes.otherWithoutDescription;\n}\n\ninterface MediaListItemMetaProps {\n  items?: ItemType[];\n}\n\nconst ItemText = ({ item }: { item: ItemType }) => {\n  if (isOtherWithoutDescription(item)) {\n    return <>{item.label}</>;\n  }\n\n  return (\n    <>\n      {item.label}: <HandleLink text={item.description}>{item.description}</HandleLink>\n    </>\n  );\n};\n\nfunction isAttributionItem(item: ItemType): item is ItemTypeWithDescription {\n  if (isOtherWithoutDescription(item)) return false;\n  return attributionTypes.some((type) => type === item.metaType);\n}\n\nconst StyledMediaListItemMeta = styled.ul`\n  margin: ${spacing.small} 0;\n  list-style: none;\n  width: 100%;\n  button,\n  a {\n    margin: 0 ${spacing.small} ${spacing.small} 0;\n  }\n`;\n\nconst StyledMediaListMetaItem = styled.li`\n  margin: 0;\n  padding: 0;\n`;\n\nexport const MediaListItemMeta = ({ items = [] }: MediaListItemMetaProps) => {\n  const attributionItems = items.filter(isAttributionItem);\n  const attributionMeta = attributionItems.map((item) => `${item.label}: ${item.description}`).join(', ');\n\n  return (\n    <StyledMediaListItemMeta property=\"cc:attributionName\" content={attributionMeta}>\n      {items.map((item) => (\n        <StyledMediaListMetaItem key={uuid()}>\n          <ItemText item={item} />\n        </StyledMediaListMetaItem>\n      ))}\n    </StyledMediaListItemMeta>\n  );\n};\n"]} */",
|
|
199
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
200
|
+
});
|
|
201
|
+
export const MediaListItemMeta = _ref8 => {
|
|
173
202
|
let {
|
|
174
203
|
items = []
|
|
175
|
-
} =
|
|
204
|
+
} = _ref8;
|
|
176
205
|
const attributionItems = items.filter(isAttributionItem);
|
|
177
206
|
const attributionMeta = attributionItems.map(item => `${item.label}: ${item.description}`).join(', ');
|
|
178
|
-
return (
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
item: item
|
|
188
|
-
})
|
|
189
|
-
}, uuid()))
|
|
190
|
-
})
|
|
191
|
-
);
|
|
207
|
+
return _jsx(StyledMediaListItemMeta, {
|
|
208
|
+
property: "cc:attributionName",
|
|
209
|
+
content: attributionMeta,
|
|
210
|
+
children: items.map(item => _jsx(StyledMediaListMetaItem, {
|
|
211
|
+
children: _jsx(ItemText, {
|
|
212
|
+
item: item
|
|
213
|
+
})
|
|
214
|
+
}, uuid()))
|
|
215
|
+
});
|
|
192
216
|
};
|
package/es/NDLAFilm/MovieGrid.js
CHANGED
|
@@ -8,7 +8,7 @@ import _styled from "@emotion/styled/base";
|
|
|
8
8
|
*/
|
|
9
9
|
|
|
10
10
|
import { useTranslation } from 'react-i18next';
|
|
11
|
-
import { breakpoints, mq, spacing
|
|
11
|
+
import { breakpoints, mq, spacing } from '@ndla/core';
|
|
12
12
|
import FilmContentCard from './FilmContentCard';
|
|
13
13
|
import { setAnimations, StyledHeadingH1 } from './filmStyles';
|
|
14
14
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
@@ -18,11 +18,11 @@ const MovieListing = /*#__PURE__*/_styled("div", {
|
|
|
18
18
|
label: "MovieListing"
|
|
19
19
|
})("display:flex;flex-wrap:wrap;gap:", spacing.normal, ";margin:", spacing.small, " 0;margin-left:", props => props.marginLeft && `${props.marginLeft}px`, ";", setAnimations(), ";margin-left:", spacing.normal, ";margin-right:", spacing.normal, ";", mq.range({
|
|
20
20
|
from: breakpoints.desktop
|
|
21
|
-
}), "{margin-left:",
|
|
21
|
+
}), "{margin-left:", spacing.xlarge, ";margin-right:", spacing.xlarge, ";}>div{opacity:0;animation-fill-mode:forwards;animation-name:fadeIn;animation-duration:300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJrRCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IHNldEFuaW1hdGlvbnMsIFN0eWxlZEhlYWRpbmdIMSB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmludGVyZmFjZSBNb3ZpZUxpc3RpbmdQcm9wcyB7XG4gIG1hcmdpbkxlZnQ/OiBudW1iZXI7XG59XG5cbmNvbnN0IE1vdmllTGlzdGluZyA9IHN0eWxlZC5kaXY8TW92aWVMaXN0aW5nUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIGdhcDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICBtYXJnaW4tbGVmdDogJHsocHJvcHMpID0+IHByb3BzLm1hcmdpbkxlZnQgJiYgYCR7cHJvcHMubWFyZ2luTGVmdH1weGB9O1xuICAke3NldEFuaW1hdGlvbnMoKX07XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnhsYXJnZX07XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueGxhcmdlfTtcbiAgfVxuICA+IGRpdiB7XG4gICAgb3BhY2l0eTogMDtcbiAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICBhbmltYXRpb24tbmFtZTogZmFkZUluO1xuICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMzAwbXM7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcyB7XG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTG9hZGluZ1BsYWNlaG9sZGVyID0gc3R5bGVkLmRpdjxMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcz5gXG4gIGhlaWdodDogJHsocHJvcHMpID0+IHByb3BzLmhlaWdodH07XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVOYW1lPzogTW92aWVSZXNvdXJjZVR5cGU7XG4gIGZldGNoaW5nTW92aWVzQnlUeXBlOiBib29sZWFuO1xuICBtb3ZpZXNCeVR5cGU6IE1vdmllVHlwZVtdO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IE1vdmllR3JpZCA9ICh7XG4gIHJlc291cmNlVHlwZU5hbWUsXG4gIGZldGNoaW5nTW92aWVzQnlUeXBlLFxuICBtb3ZpZXNCeVR5cGUsXG4gIHJlc291cmNlVHlwZXMsXG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodCxcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8c2VjdGlvbj5cbiAgICAgIDxTdHlsZWRIZWFkaW5nSDE+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L1N0eWxlZEhlYWRpbmdIMT5cbiAgICAgIDxNb3ZpZUxpc3Rpbmc+XG4gICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZSAmJiA8TG9hZGluZ1BsYWNlaG9sZGVyIGhlaWdodD17bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fSAvPn1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZCBrZXk9e2luZGV4fSBoaWRlVGFncyBtb3ZpZT17bW92aWV9IHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9IGxhenkgdHlwZT1cImxpc3RcIiAvPlxuICAgICAgICAgICkpfVxuICAgICAgPC9Nb3ZpZUxpc3Rpbmc+XG4gICAgPC9zZWN0aW9uPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgTW92aWVHcmlkO1xuIl19 */"));
|
|
22
22
|
const LoadingPlaceholder = /*#__PURE__*/_styled("div", {
|
|
23
23
|
target: "e1t64qur0",
|
|
24
24
|
label: "LoadingPlaceholder"
|
|
25
|
-
})("height:", props => props.height, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
25
|
+
})("height:", props => props.height, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEM4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IHNldEFuaW1hdGlvbnMsIFN0eWxlZEhlYWRpbmdIMSB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmludGVyZmFjZSBNb3ZpZUxpc3RpbmdQcm9wcyB7XG4gIG1hcmdpbkxlZnQ/OiBudW1iZXI7XG59XG5cbmNvbnN0IE1vdmllTGlzdGluZyA9IHN0eWxlZC5kaXY8TW92aWVMaXN0aW5nUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIGdhcDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICBtYXJnaW4tbGVmdDogJHsocHJvcHMpID0+IHByb3BzLm1hcmdpbkxlZnQgJiYgYCR7cHJvcHMubWFyZ2luTGVmdH1weGB9O1xuICAke3NldEFuaW1hdGlvbnMoKX07XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnhsYXJnZX07XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcueGxhcmdlfTtcbiAgfVxuICA+IGRpdiB7XG4gICAgb3BhY2l0eTogMDtcbiAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICBhbmltYXRpb24tbmFtZTogZmFkZUluO1xuICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMzAwbXM7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcyB7XG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTG9hZGluZ1BsYWNlaG9sZGVyID0gc3R5bGVkLmRpdjxMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcz5gXG4gIGhlaWdodDogJHsocHJvcHMpID0+IHByb3BzLmhlaWdodH07XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICByZXNvdXJjZVR5cGVOYW1lPzogTW92aWVSZXNvdXJjZVR5cGU7XG4gIGZldGNoaW5nTW92aWVzQnlUeXBlOiBib29sZWFuO1xuICBtb3ZpZXNCeVR5cGU6IE1vdmllVHlwZVtdO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IE1vdmllR3JpZCA9ICh7XG4gIHJlc291cmNlVHlwZU5hbWUsXG4gIGZldGNoaW5nTW92aWVzQnlUeXBlLFxuICBtb3ZpZXNCeVR5cGUsXG4gIHJlc291cmNlVHlwZXMsXG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodCxcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8c2VjdGlvbj5cbiAgICAgIDxTdHlsZWRIZWFkaW5nSDE+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L1N0eWxlZEhlYWRpbmdIMT5cbiAgICAgIDxNb3ZpZUxpc3Rpbmc+XG4gICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZSAmJiA8TG9hZGluZ1BsYWNlaG9sZGVyIGhlaWdodD17bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fSAvPn1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZCBrZXk9e2luZGV4fSBoaWRlVGFncyBtb3ZpZT17bW92aWV9IHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9IGxhenkgdHlwZT1cImxpc3RcIiAvPlxuICAgICAgICAgICkpfVxuICAgICAgPC9Nb3ZpZUxpc3Rpbmc+XG4gICAgPC9zZWN0aW9uPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgTW92aWVHcmlkO1xuIl19 */"));
|
|
26
26
|
const MovieGrid = _ref => {
|
|
27
27
|
let {
|
|
28
28
|
resourceTypeName,
|
|
@@ -8,7 +8,7 @@ import _styled from "@emotion/styled/base";
|
|
|
8
8
|
*/
|
|
9
9
|
|
|
10
10
|
import { css } from '@emotion/react';
|
|
11
|
-
import { fonts, spacing, colors, mq, breakpoints
|
|
11
|
+
import { fonts, spacing, colors, mq, breakpoints } from '@ndla/core';
|
|
12
12
|
export const setAnimations = () => {
|
|
13
13
|
const styles = {};
|
|
14
14
|
for (let i = 1; i < 20; i++) {
|
|
@@ -20,12 +20,12 @@ export const setAnimations = () => {
|
|
|
20
20
|
};
|
|
21
21
|
const headingStyle = /*#__PURE__*/css(fonts.sizes('22px', '26px'), ";font-weight:", fonts.weight.semibold, ";text-transform:uppercase;letter-spacing:0.05em;color:", colors.white, ";margin:", spacing.xsmall, " 0;small{font-weight:normal;padding-left:", spacing.small, ";color:", colors.brand.grey, ";}margin-left:", spacing.normal, ";margin-right:", spacing.normal, ";", mq.range({
|
|
22
22
|
from: breakpoints.desktop
|
|
23
|
-
}), "{margin-left:",
|
|
23
|
+
}), "{margin-left:", spacing.xlarge, ";margin-right:", spacing.xlarge, ";};label:headingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0J3QiIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuZXhwb3J0IGNvbnN0IHNldEFuaW1hdGlvbnMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlczogYW55ID0ge307XG4gIGZvciAobGV0IGkgPSAxOyBpIDwgMjA7IGkrKykge1xuICAgIHN0eWxlc1tgPiBkaXY6bnRoLWNoaWxkKCR7aSArIDF9KWBdID0ge1xuICAgICAgJ2FuaW1hdGlvbi1kZWxheSc6IGAke2kgKiA1MH1tc2AsXG4gICAgfTtcbiAgfVxuICByZXR1cm4gc3R5bGVzO1xufTtcblxuY29uc3QgaGVhZGluZ1N0eWxlID0gY3NzYFxuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzI2cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gIGxldHRlci1zcGFjaW5nOiAwLjA1ZW07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgc21hbGwge1xuICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgfVxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy54bGFyZ2V9O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLnhsYXJnZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDEgPSBzdHlsZWQuaDFgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDIgPSBzdHlsZWQuaDJgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG4iXX0= */"));
|
|
24
24
|
export const StyledHeadingH1 = /*#__PURE__*/_styled("h1", {
|
|
25
25
|
target: "e1uw8gqd1",
|
|
26
26
|
label: "StyledHeadingH1"
|
|
27
|
-
})(headingStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
27
|
+
})(headingStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEN3QyIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuZXhwb3J0IGNvbnN0IHNldEFuaW1hdGlvbnMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlczogYW55ID0ge307XG4gIGZvciAobGV0IGkgPSAxOyBpIDwgMjA7IGkrKykge1xuICAgIHN0eWxlc1tgPiBkaXY6bnRoLWNoaWxkKCR7aSArIDF9KWBdID0ge1xuICAgICAgJ2FuaW1hdGlvbi1kZWxheSc6IGAke2kgKiA1MH1tc2AsXG4gICAgfTtcbiAgfVxuICByZXR1cm4gc3R5bGVzO1xufTtcblxuY29uc3QgaGVhZGluZ1N0eWxlID0gY3NzYFxuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzI2cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gIGxldHRlci1zcGFjaW5nOiAwLjA1ZW07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgc21hbGwge1xuICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgfVxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy54bGFyZ2V9O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLnhsYXJnZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDEgPSBzdHlsZWQuaDFgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDIgPSBzdHlsZWQuaDJgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG4iXX0= */"));
|
|
28
28
|
export const StyledHeadingH2 = /*#__PURE__*/_styled("h2", {
|
|
29
29
|
target: "e1uw8gqd0",
|
|
30
30
|
label: "StyledHeadingH2"
|
|
31
|
-
})(headingStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
})(headingStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEN3QyIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuZXhwb3J0IGNvbnN0IHNldEFuaW1hdGlvbnMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlczogYW55ID0ge307XG4gIGZvciAobGV0IGkgPSAxOyBpIDwgMjA7IGkrKykge1xuICAgIHN0eWxlc1tgPiBkaXY6bnRoLWNoaWxkKCR7aSArIDF9KWBdID0ge1xuICAgICAgJ2FuaW1hdGlvbi1kZWxheSc6IGAke2kgKiA1MH1tc2AsXG4gICAgfTtcbiAgfVxuICByZXR1cm4gc3R5bGVzO1xufTtcblxuY29uc3QgaGVhZGluZ1N0eWxlID0gY3NzYFxuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzI2cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gIGxldHRlci1zcGFjaW5nOiAwLjA1ZW07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgc21hbGwge1xuICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgfVxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy54bGFyZ2V9O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLnhsYXJnZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDEgPSBzdHlsZWQuaDFgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDIgPSBzdHlsZWQuaDJgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG4iXX0= */"));
|