@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.
Files changed (73) hide show
  1. package/es/Footer/Footer.js +9 -9
  2. package/es/Footer/FooterLinks.js +8 -8
  3. package/es/FrontpageArticle/FrontpageArticle.js +2 -2
  4. package/es/LearningPaths/LearningPathInformation.js +4 -4
  5. package/es/LearningPaths/LearningPathLastStepNavigation.js +5 -5
  6. package/es/LearningPaths/LearningPathMenuAside.js +5 -5
  7. package/es/LearningPaths/LearningPathMenuContent.js +7 -7
  8. package/es/MediaList/MediaList.js +94 -70
  9. package/es/NDLAFilm/MovieGrid.js +3 -3
  10. package/es/NDLAFilm/filmStyles.js +4 -4
  11. package/es/Resource/BlockResource.js +23 -10
  12. package/es/Resource/ListResource.js +16 -10
  13. package/es/Resource/resourceComponents.js +19 -11
  14. package/es/Subject/SubjectHeader.js +5 -5
  15. package/es/all.css +1 -1
  16. package/es/locale/messages-en.js +6 -3
  17. package/es/locale/messages-nb.js +5 -2
  18. package/es/locale/messages-nn.js +5 -2
  19. package/es/locale/messages-se.js +5 -2
  20. package/es/locale/messages-sma.js +5 -2
  21. package/lib/Footer/Footer.js +9 -9
  22. package/lib/Footer/FooterLinks.js +7 -7
  23. package/lib/FrontpageArticle/FrontpageArticle.js +1 -1
  24. package/lib/LearningPaths/LearningPathInformation.js +4 -4
  25. package/lib/LearningPaths/LearningPathLastStepNavigation.js +4 -4
  26. package/lib/LearningPaths/LearningPathMenuAside.js +5 -5
  27. package/lib/LearningPaths/LearningPathMenuContent.js +7 -7
  28. package/lib/MediaList/MediaList.d.ts +4 -18
  29. package/lib/MediaList/MediaList.js +94 -73
  30. package/lib/NDLAFilm/MovieGrid.js +2 -2
  31. package/lib/NDLAFilm/filmStyles.js +3 -3
  32. package/lib/Resource/BlockResource.d.ts +1 -2
  33. package/lib/Resource/BlockResource.js +22 -9
  34. package/lib/Resource/ListResource.js +15 -9
  35. package/lib/Resource/resourceComponents.js +19 -11
  36. package/lib/Subject/SubjectHeader.js +4 -4
  37. package/lib/all.css +1 -1
  38. package/lib/locale/messages-en.d.ts +3 -0
  39. package/lib/locale/messages-en.js +6 -3
  40. package/lib/locale/messages-nb.d.ts +3 -0
  41. package/lib/locale/messages-nb.js +5 -2
  42. package/lib/locale/messages-nn.d.ts +3 -0
  43. package/lib/locale/messages-nn.js +5 -2
  44. package/lib/locale/messages-se.d.ts +3 -0
  45. package/lib/locale/messages-se.js +5 -2
  46. package/lib/locale/messages-sma.d.ts +3 -0
  47. package/lib/locale/messages-sma.js +5 -2
  48. package/package.json +17 -17
  49. package/src/Footer/Footer.tsx +7 -9
  50. package/src/Footer/FooterLinks.tsx +1 -1
  51. package/src/FrontpageArticle/FrontpageArticle.tsx +3 -3
  52. package/src/LearningPaths/LearningPathInformation.tsx +1 -1
  53. package/src/LearningPaths/LearningPathLastStepNavigation.tsx +2 -2
  54. package/src/LearningPaths/LearningPathMenuAside.tsx +1 -1
  55. package/src/LearningPaths/LearningPathMenuContent.tsx +2 -2
  56. package/src/Logo/component.logo.scss +3 -0
  57. package/src/MediaList/MediaList.tsx +93 -50
  58. package/src/NDLAFilm/MovieGrid.tsx +3 -3
  59. package/src/NDLAFilm/filmStyles.ts +3 -3
  60. package/src/Resource/BlockResource.stories.tsx +0 -3
  61. package/src/Resource/BlockResource.tsx +9 -8
  62. package/src/Resource/ListResource.stories.tsx +0 -3
  63. package/src/Resource/ListResource.tsx +11 -8
  64. package/src/Resource/resourceComponents.tsx +0 -2
  65. package/src/Subject/SubjectHeader.tsx +3 -3
  66. package/src/locale/messages-en.ts +4 -1
  67. package/src/locale/messages-nb.ts +3 -0
  68. package/src/locale/messages-nn.ts +3 -0
  69. package/src/locale/messages-se.ts +3 -0
  70. package/src/locale/messages-sma.ts +3 -0
  71. package/src/main.scss +0 -2
  72. package/src/MediaList/component.medialist.scss +0 -93
  73. 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 BEMHelper from 'react-bem-helper';
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 oClasses = new BEMHelper({
20
- name: 'media',
21
- prefix: 'o-'
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("ul", {
32
- ...cClasses(),
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("li", {
41
- ...oClasses(undefined, undefined, cClasses('item').className),
46
+ return _jsx(StyledMediaListItem, {
47
+ ...rest,
42
48
  children: children
43
49
  });
44
50
  };
45
51
  const ImageWrapper = /*#__PURE__*/_styled("div", {
46
- target: "er7hlkd1",
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: "er7hlkd0",
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
- export const MediaListCCLink = _ref4 => {
68
- let {
69
- children,
70
- url
71
- } = _ref4;
72
- return _jsx("a", {
73
- rel: "noopener noreferrer license",
74
- href: url,
75
- children: children
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
- } = _ref5;
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("div", {
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 ? _jsxs("h3", {
108
- className: "c-medialist__title",
109
- children: [title, " "]
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(MediaListCCLink, {
116
- url: license.url,
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
- export const MediaListItemActions = _ref6 => {
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
- } = _ref6;
125
- return _jsx("div", {
126
- ...cClasses('actions'),
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 = _ref7 => {
144
+ export const HandleLink = _ref6 => {
132
145
  let {
133
146
  text,
134
147
  children
135
- } = _ref7;
148
+ } = _ref6;
136
149
  if (isLink(text)) {
137
- return _jsx("a", {
138
- href: text,
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 = _ref8 => {
165
+ const ItemText = _ref7 => {
153
166
  let {
154
167
  item
155
- } = _ref8;
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
- export const MediaListItemMeta = _ref9 => {
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
- } = _ref9;
204
+ } = _ref8;
176
205
  const attributionItems = items.filter(isAttributionItem);
177
206
  const attributionMeta = attributionItems.map(item => `${item.label}: ${item.description}`).join(', ');
178
- return (
179
- // eslint-disable-next-line react/no-unknown-property
180
- _jsx("ul", {
181
- ...cClasses('actions'),
182
- property: "cc:attributionName",
183
- content: attributionMeta,
184
- children: items.map(item => _jsx("li", {
185
- className: "c-medialist__meta-item",
186
- children: _jsx(ItemText, {
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
  };
@@ -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, spacingUnit } from '@ndla/core';
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:", spacingUnit * 3, "px;margin-right:", spacingUnit * 3, "px;}>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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJrRCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nVW5pdCAqIDN9cHg7XG4gIH1cbiAgPiBkaXYge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgYW5pbWF0aW9uLW5hbWU6IGZhZGVJbjtcbiAgICBhbmltYXRpb24tZHVyYXRpb246IDMwMG1zO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgTG9hZGluZ1BsYWNlaG9sZGVyUHJvcHMge1xuICBoZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IExvYWRpbmdQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXY8TG9hZGluZ1BsYWNlaG9sZGVyUHJvcHM+YFxuICBoZWlnaHQ6ICR7KHByb3BzKSA9PiBwcm9wcy5oZWlnaHR9O1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlTmFtZT86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBmZXRjaGluZ01vdmllc0J5VHlwZTogYm9vbGVhbjtcbiAgbW92aWVzQnlUeXBlOiBNb3ZpZVR5cGVbXTtcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBNb3ZpZUdyaWQgPSAoe1xuICByZXNvdXJjZVR5cGVOYW1lLFxuICBmZXRjaGluZ01vdmllc0J5VHlwZSxcbiAgbW92aWVzQnlUeXBlLFxuICByZXNvdXJjZVR5cGVzLFxuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPHNlY3Rpb24+XG4gICAgICA8U3R5bGVkSGVhZGluZ0gxPlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nPlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgPExvYWRpbmdQbGFjZWhvbGRlciBoZWlnaHQ9e2xvYWRpbmdQbGFjZWhvbGRlckhlaWdodH0gLz59XG4gICAgICAgIHshZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiZcbiAgICAgICAgICBtb3ZpZXNCeVR5cGUubWFwKChtb3ZpZSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgIDxGaWxtQ29udGVudENhcmQga2V5PXtpbmRleH0gaGlkZVRhZ3MgbW92aWU9e21vdmllfSByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfSBsYXp5IHR5cGU9XCJsaXN0XCIgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEM4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nVW5pdCAqIDN9cHg7XG4gIH1cbiAgPiBkaXYge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgYW5pbWF0aW9uLW5hbWU6IGZhZGVJbjtcbiAgICBhbmltYXRpb24tZHVyYXRpb246IDMwMG1zO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgTG9hZGluZ1BsYWNlaG9sZGVyUHJvcHMge1xuICBoZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IExvYWRpbmdQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXY8TG9hZGluZ1BsYWNlaG9sZGVyUHJvcHM+YFxuICBoZWlnaHQ6ICR7KHByb3BzKSA9PiBwcm9wcy5oZWlnaHR9O1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlTmFtZT86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBmZXRjaGluZ01vdmllc0J5VHlwZTogYm9vbGVhbjtcbiAgbW92aWVzQnlUeXBlOiBNb3ZpZVR5cGVbXTtcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBNb3ZpZUdyaWQgPSAoe1xuICByZXNvdXJjZVR5cGVOYW1lLFxuICBmZXRjaGluZ01vdmllc0J5VHlwZSxcbiAgbW92aWVzQnlUeXBlLFxuICByZXNvdXJjZVR5cGVzLFxuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPHNlY3Rpb24+XG4gICAgICA8U3R5bGVkSGVhZGluZ0gxPlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nPlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgPExvYWRpbmdQbGFjZWhvbGRlciBoZWlnaHQ9e2xvYWRpbmdQbGFjZWhvbGRlckhlaWdodH0gLz59XG4gICAgICAgIHshZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiZcbiAgICAgICAgICBtb3ZpZXNCeVR5cGUubWFwKChtb3ZpZSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgIDxGaWxtQ29udGVudENhcmQga2V5PXtpbmRleH0gaGlkZVRhZ3MgbW92aWU9e21vdmllfSByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfSBsYXp5IHR5cGU9XCJsaXN0XCIgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
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, spacingUnit } from '@ndla/core';
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:", spacingUnit * 3, "px;margin-right:", spacingUnit * 3, "px;};label:headingStyle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0J3QiIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBzZXRBbmltYXRpb25zID0gKCkgPT4ge1xuICBjb25zdCBzdHlsZXM6IGFueSA9IHt9O1xuICBmb3IgKGxldCBpID0gMTsgaSA8IDIwOyBpKyspIHtcbiAgICBzdHlsZXNbYD4gZGl2Om50aC1jaGlsZCgke2kgKyAxfSlgXSA9IHtcbiAgICAgICdhbmltYXRpb24tZGVsYXknOiBgJHtpICogNTB9bXNgLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0eWxlcztcbn07XG5cbmNvbnN0IGhlYWRpbmdTdHlsZSA9IGNzc2BcbiAgJHtmb250cy5zaXplcygnMjJweCcsICcyNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46ICR7c3BhY2luZy54c21hbGx9IDA7XG4gIHNtYWxsIHtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleX07XG4gIH1cbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMuZGVza3RvcCB9KX0ge1xuICAgIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gxID0gc3R5bGVkLmgxYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gyID0gc3R5bGVkLmgyYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuIl19 */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEN3QyIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBzZXRBbmltYXRpb25zID0gKCkgPT4ge1xuICBjb25zdCBzdHlsZXM6IGFueSA9IHt9O1xuICBmb3IgKGxldCBpID0gMTsgaSA8IDIwOyBpKyspIHtcbiAgICBzdHlsZXNbYD4gZGl2Om50aC1jaGlsZCgke2kgKyAxfSlgXSA9IHtcbiAgICAgICdhbmltYXRpb24tZGVsYXknOiBgJHtpICogNTB9bXNgLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0eWxlcztcbn07XG5cbmNvbnN0IGhlYWRpbmdTdHlsZSA9IGNzc2BcbiAgJHtmb250cy5zaXplcygnMjJweCcsICcyNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46ICR7c3BhY2luZy54c21hbGx9IDA7XG4gIHNtYWxsIHtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleX07XG4gIH1cbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMuZGVza3RvcCB9KX0ge1xuICAgIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gxID0gc3R5bGVkLmgxYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gyID0gc3R5bGVkLmgyYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuIl19 */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEN3QyIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBzZXRBbmltYXRpb25zID0gKCkgPT4ge1xuICBjb25zdCBzdHlsZXM6IGFueSA9IHt9O1xuICBmb3IgKGxldCBpID0gMTsgaSA8IDIwOyBpKyspIHtcbiAgICBzdHlsZXNbYD4gZGl2Om50aC1jaGlsZCgke2kgKyAxfSlgXSA9IHtcbiAgICAgICdhbmltYXRpb24tZGVsYXknOiBgJHtpICogNTB9bXNgLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0eWxlcztcbn07XG5cbmNvbnN0IGhlYWRpbmdTdHlsZSA9IGNzc2BcbiAgJHtmb250cy5zaXplcygnMjJweCcsICcyNnB4Jyl9O1xuICBmb250LXdlaWdodDogJHtmb250cy53ZWlnaHQuc2VtaWJvbGR9O1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICBsZXR0ZXItc3BhY2luZzogMC4wNWVtO1xuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46ICR7c3BhY2luZy54c21hbGx9IDA7XG4gIHNtYWxsIHtcbiAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleX07XG4gIH1cbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMuZGVza3RvcCB9KX0ge1xuICAgIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gxID0gc3R5bGVkLmgxYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVhZGluZ0gyID0gc3R5bGVkLmgyYFxuICAke2hlYWRpbmdTdHlsZX07XG5gO1xuIl19 */"));
31
+ })(headingStyle, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEN3QyIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuZXhwb3J0IGNvbnN0IHNldEFuaW1hdGlvbnMgPSAoKSA9PiB7XG4gIGNvbnN0IHN0eWxlczogYW55ID0ge307XG4gIGZvciAobGV0IGkgPSAxOyBpIDwgMjA7IGkrKykge1xuICAgIHN0eWxlc1tgPiBkaXY6bnRoLWNoaWxkKCR7aSArIDF9KWBdID0ge1xuICAgICAgJ2FuaW1hdGlvbi1kZWxheSc6IGAke2kgKiA1MH1tc2AsXG4gICAgfTtcbiAgfVxuICByZXR1cm4gc3R5bGVzO1xufTtcblxuY29uc3QgaGVhZGluZ1N0eWxlID0gY3NzYFxuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzI2cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gIGxldHRlci1zcGFjaW5nOiAwLjA1ZW07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgc21hbGwge1xuICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgfVxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy54bGFyZ2V9O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLnhsYXJnZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDEgPSBzdHlsZWQuaDFgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDIgPSBzdHlsZWQuaDJgXG4gICR7aGVhZGluZ1N0eWxlfTtcbmA7XG4iXX0= */"));