@ndla/ui 33.4.5 → 34.0.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 (56) hide show
  1. package/es/Article/Article.js +7 -7
  2. package/es/Article/ArticleByline.js +14 -14
  3. package/es/Article/ArticleHeaderWrapper.js +4 -2
  4. package/es/BannerCard/BannerCard.js +13 -10
  5. package/es/CompetenceGoalTab/CompetenceGoalItem.js +69 -51
  6. package/es/CompetenceGoalTab/CompetenceGoalTab.js +25 -47
  7. package/es/CompetenceGoalTab/CompetenceItem.js +38 -90
  8. package/es/CompetenceGoals/CompetenceGoalsDialog.js +4 -4
  9. package/es/locale/messages-en.js +6 -3
  10. package/es/locale/messages-nb.js +6 -3
  11. package/es/locale/messages-nn.js +6 -3
  12. package/es/locale/messages-se.js +6 -3
  13. package/es/locale/messages-sma.js +6 -3
  14. package/lib/Article/Article.d.ts +3 -3
  15. package/lib/Article/Article.js +7 -7
  16. package/lib/Article/ArticleByline.js +14 -14
  17. package/lib/Article/ArticleHeaderWrapper.d.ts +2 -2
  18. package/lib/Article/ArticleHeaderWrapper.js +4 -2
  19. package/lib/BannerCard/BannerCard.d.ts +12 -3
  20. package/lib/BannerCard/BannerCard.js +13 -10
  21. package/lib/CompetenceGoalTab/CompetenceGoalItem.js +69 -51
  22. package/lib/CompetenceGoalTab/CompetenceGoalTab.d.ts +1 -2
  23. package/lib/CompetenceGoalTab/CompetenceGoalTab.js +23 -46
  24. package/lib/CompetenceGoalTab/CompetenceItem.d.ts +6 -2
  25. package/lib/CompetenceGoalTab/CompetenceItem.js +37 -89
  26. package/lib/CompetenceGoals/CompetenceGoalsDialog.js +4 -4
  27. package/lib/locale/messages-en.d.ts +4 -1
  28. package/lib/locale/messages-en.js +6 -3
  29. package/lib/locale/messages-nb.d.ts +4 -1
  30. package/lib/locale/messages-nb.js +6 -3
  31. package/lib/locale/messages-nn.d.ts +4 -1
  32. package/lib/locale/messages-nn.js +6 -3
  33. package/lib/locale/messages-se.d.ts +4 -1
  34. package/lib/locale/messages-se.js +6 -3
  35. package/lib/locale/messages-sma.d.ts +4 -1
  36. package/lib/locale/messages-sma.js +6 -3
  37. package/lib/types.d.ts +1 -1
  38. package/package.json +2 -2
  39. package/src/Article/Article.tsx +6 -6
  40. package/src/Article/ArticleByline.tsx +12 -12
  41. package/src/Article/ArticleHeaderWrapper.tsx +9 -3
  42. package/src/BannerCard/BannerCard.tsx +7 -7
  43. package/src/CompetenceGoalTab/CompetenceGoalItem.tsx +36 -39
  44. package/src/CompetenceGoalTab/CompetenceGoalTab.tsx +32 -76
  45. package/src/CompetenceGoalTab/CompetenceItem.tsx +55 -74
  46. package/src/CompetenceGoals/CompetenceGoalsDialog.tsx +1 -1
  47. package/src/locale/messages-en.ts +7 -3
  48. package/src/locale/messages-nb.ts +7 -3
  49. package/src/locale/messages-nn.ts +7 -3
  50. package/src/locale/messages-se.ts +7 -3
  51. package/src/locale/messages-sma.ts +7 -3
  52. package/src/types.ts +1 -1
  53. package/es/CompetenceGoalTab/SearchButton.js +0 -46
  54. package/lib/CompetenceGoalTab/SearchButton.d.ts +0 -14
  55. package/lib/CompetenceGoalTab/SearchButton.js +0 -53
  56. package/src/CompetenceGoalTab/SearchButton.tsx +0 -54
@@ -257,6 +257,8 @@ var messages = _objectSpread(_objectSpread({
257
257
  removeFavorite: 'Fjern favorittfag',
258
258
  removeConfirmed: '{{subject}} er fjernet fra favorittfag',
259
259
  addConfirmed: '{{subject}} er lagt til som favorittfag',
260
+ subjectFavoritePitch: 'Ønsker du å favorittmerke dette faget?',
261
+ subjectFavoriteGuide: 'For å favorittmerke et fag må du logge inn på Min NDLA. Du finner faget øverst på denne siden etter at du har logget inn.',
260
262
  shows: 'Viser'
261
263
  },
262
264
  topicPage: {
@@ -431,7 +433,7 @@ var messages = _objectSpread(_objectSpread({
431
433
  useCompentenceGoalsFilter: 'Bruk filter',
432
434
  closeCompentenceGoalsFilter: 'Lukk filter',
433
435
  competenceGoalsNarrowBackButton: 'Tilbake',
434
- competenceGoalResourceSearchText: 'Søk alle ressurser som passer til dette kompetansemålet',
436
+ competenceGoalResourceSearchText: 'Vis ressursar til kompetansemål {{goal}}',
435
437
  competenceGoalShowExtra: 'Vis støtte til læreplanen',
436
438
  competenceGoalCloseExtra: 'Skjul støtte til læreplanen',
437
439
  competenceCoreLabel: 'Kjerneelement',
@@ -442,9 +444,10 @@ var messages = _objectSpread(_objectSpread({
442
444
  competenceSubjectSearchText: 'Gå til fagsiden',
443
445
  competenceGoalClose: 'Lukk',
444
446
  competenceGoalTitle: 'Målet er at eleven skal kunne:',
445
- competenceTabLK06label: 'Kompetansemål (LK06)',
446
- competenceTabLK20label: 'Kompetansemål (LK20)',
447
+ competenceTabLK20label: 'Kompetansemål',
448
+ competenceTabLK20Tooltip: 'Vis kompetansemål',
447
449
  competenceTabCorelabel: 'Kjerneelement',
450
+ competenceTabCoreTooltip: 'Vis kjerneelementer',
448
451
  competenceGoalItem: {
449
452
  title: 'Kompetansemål og vurdering'
450
453
  },
@@ -35,11 +35,13 @@ type Props = {
35
35
  article: ArticleType;
36
36
  icon?: ReactNode;
37
37
  licenseBox?: ReactNode;
38
+ competenceGoalsLoading?: boolean;
38
39
  modifier?: string;
39
40
  children?: ReactNode;
40
41
  messages: Messages;
41
42
  locale: Locale;
42
43
  messageBoxLinks?: [];
44
+ copyText?: string;
43
45
  competenceGoals?: ((inp: {
44
46
  Dialog: ComponentType;
45
47
  dialogProps: {
@@ -47,10 +49,8 @@ type Props = {
47
49
  onClose: () => void;
48
50
  };
49
51
  }) => ReactNode) | ReactNode | null;
50
- competenceGoalTypes?: string[];
51
52
  id: string;
52
53
  renderMarkdown: (text: string) => string;
53
- copyPageUrlLink?: string;
54
54
  printUrl?: string;
55
55
  notions?: {
56
56
  list: ConceptNotionType[];
@@ -58,5 +58,5 @@ type Props = {
58
58
  };
59
59
  accessMessage?: string;
60
60
  };
61
- export declare const Article: ({ article, icon, licenseBox, modifier, messages, messageBoxLinks, children, competenceGoals, competenceGoalTypes, copyPageUrlLink, id, locale, notions, printUrl, renderMarkdown, accessMessage, heartButton, }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
61
+ export declare const Article: ({ article, icon, licenseBox, modifier, messages, messageBoxLinks, children, competenceGoals, competenceGoalsLoading, id, locale, notions, printUrl, renderMarkdown, accessMessage, heartButton, copyText, }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
62
62
  export default Article;
@@ -103,7 +103,7 @@ var MSGboxWrapper = /*#__PURE__*/(0, _base["default"])("div", {
103
103
  } : {
104
104
  name: "15u9bv0",
105
105
  styles: "margin-bottom:50px",
106
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAgGgC","file":"Article.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 React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */",
106
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAgGgC","file":"Article.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 React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  competenceGoalsLoading?: boolean;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  copyText?: string;\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  id: string;\n  renderMarkdown: (text: string) => string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalsLoading,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n  copyText,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalsLoading={competenceGoalsLoading}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copySourceReference={copyText}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */",
107
107
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
108
108
  });
109
109
  var ArticleFavoritesButtonWrapper = /*#__PURE__*/(0, _base["default"])("div", {
@@ -115,7 +115,7 @@ var ArticleFavoritesButtonWrapper = /*#__PURE__*/(0, _base["default"])("div", {
115
115
  from: _core.breakpoints.tabletWide
116
116
  }), "{transform:translate(", _core.spacing.large, ", -", _core.spacing.medium, ");}", _core.mq.range({
117
117
  from: _core.breakpoints.desktop
118
- }), "{transform:translate(", _core.spacingUnit * 5.5, "px, -", _core.spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAoGgD","file":"Article.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 React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */"));
118
+ }), "{transform:translate(", _core.spacingUnit * 5.5, "px, -", _core.spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAoGgD","file":"Article.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 React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  competenceGoalsLoading?: boolean;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  copyText?: string;\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  id: string;\n  renderMarkdown: (text: string) => string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalsLoading,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n  copyText,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalsLoading={competenceGoalsLoading}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copySourceReference={copyText}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */"));
119
119
  var getArticleContent = function getArticleContent(content, locale) {
120
120
  switch (_typeof(content)) {
121
121
  case 'string':
@@ -138,15 +138,15 @@ var Article = function Article(_ref4) {
138
138
  messageBoxLinks = _ref4.messageBoxLinks,
139
139
  children = _ref4.children,
140
140
  competenceGoals = _ref4.competenceGoals,
141
- competenceGoalTypes = _ref4.competenceGoalTypes,
142
- copyPageUrlLink = _ref4.copyPageUrlLink,
141
+ competenceGoalsLoading = _ref4.competenceGoalsLoading,
143
142
  id = _ref4.id,
144
143
  locale = _ref4.locale,
145
144
  notions = _ref4.notions,
146
145
  printUrl = _ref4.printUrl,
147
146
  renderMarkdown = _ref4.renderMarkdown,
148
147
  accessMessage = _ref4.accessMessage,
149
- heartButton = _ref4.heartButton;
148
+ heartButton = _ref4.heartButton,
149
+ copyText = _ref4.copyText;
150
150
  var _useIntersectionObser = (0, _hooks.useIntersectionObserver)({
151
151
  root: null,
152
152
  rootMargin: '400px',
@@ -201,7 +201,7 @@ var Article = function Article(_ref4) {
201
201
  })
202
202
  }), (0, _jsxRuntime.jsxs)(_ArticleHeaderWrapper["default"], {
203
203
  competenceGoals: competenceGoals,
204
- competenceGoalTypes: competenceGoalTypes,
204
+ competenceGoalsLoading: competenceGoalsLoading,
205
205
  children: [heartButton ? (0, _jsxRuntime.jsx)(ArticleFavoritesButtonWrapper, {
206
206
  children: heartButton
207
207
  }) : null, (0, _jsxRuntime.jsx)(ArticleTitle, {
@@ -225,7 +225,7 @@ var Article = function Article(_ref4) {
225
225
  children: [footNotes && footNotes.length > 0 && (0, _jsxRuntime.jsx)(_ArticleFootNotes["default"], {
226
226
  footNotes: footNotes
227
227
  }), (0, _jsxRuntime.jsx)(_ArticleByline["default"], {
228
- copyPageUrlLink: copyPageUrlLink,
228
+ copySourceReference: copyText,
229
229
  authors: authors,
230
230
  suppliers: rightsholders,
231
231
  published: published,
@@ -21,7 +21,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
21
21
  var Wrapper = /*#__PURE__*/(0, _base["default"])("div", {
22
22
  target: "eeu23se3",
23
23
  label: "Wrapper"
24
- })("margin-top:", _core.spacing.normal, ";padding-top:", _core.spacing.normal, ";padding-bottom:", _core.spacing.xsmall, ";border-top:1px solid ", _core.colors.brand.greyLight, ";", _core.fonts.sizes('14px', '18px'), ";font-family:", _core.fonts.sans, ";color:", _core.colors.brand.greyDark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkB0B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            variant=\"outline\"\n            shape=\"pill\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
24
+ })("margin-top:", _core.spacing.normal, ";padding-top:", _core.spacing.normal, ";padding-bottom:", _core.spacing.xsmall, ";border-top:1px solid ", _core.colors.brand.greyLight, ";", _core.fonts.sizes('14px', '18px'), ";font-family:", _core.fonts.sans, ";color:", _core.colors.brand.greyDark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkB0B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
25
25
  var TextWrapper = /*#__PURE__*/(0, _base["default"])("div", {
26
26
  target: "eeu23se2",
27
27
  label: "TextWrapper"
@@ -31,7 +31,7 @@ var TextWrapper = /*#__PURE__*/(0, _base["default"])("div", {
31
31
  } : {
32
32
  name: "1r0yqr6",
33
33
  styles: "margin-top:10px",
34
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA4B8B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            variant=\"outline\"\n            shape=\"pill\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */",
34
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA4B8B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */",
35
35
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
36
36
  });
37
37
  var ButtonWrapper = /*#__PURE__*/(0, _base["default"])("div", {
@@ -43,13 +43,13 @@ var ButtonWrapper = /*#__PURE__*/(0, _base["default"])("div", {
43
43
  } : {
44
44
  name: "6nmkk4",
45
45
  styles: "margin-top:18px;button{margin-bottom:10px;margin-right:16px;}",
46
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAgCgC","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            variant=\"outline\"\n            shape=\"pill\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */",
46
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAgCgC","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */",
47
47
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
48
  });
49
49
  var PrimaryContributorsWrapper = /*#__PURE__*/(0, _base["default"])("span", {
50
50
  target: "eeu23se0",
51
51
  label: "PrimaryContributorsWrapper"
52
- })("margin-left:", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAwC8C","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            variant=\"outline\"\n            shape=\"pill\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
52
+ })("margin-left:", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAwC8C","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport Modal, { ModalHeader, ModalBody, ModalCloseButton } from '@ndla/modal';\nimport { CopyButton, ButtonV2 } from '@ndla/button';\nimport { colors, fonts, spacing } from '@ndla/core';\nimport { copyTextToClipboard, printPage } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { LicenseByline, getLicenseByAbbreviation } from '@ndla/licenses';\nimport { TFunction } from 'i18next';\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes('14px', '18px')};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  margin-top: 10px;\n`;\n\nconst ButtonWrapper = styled.div`\n  margin-top: 18px;\n  button {\n    margin-bottom: 10px;\n    margin-right: 16px;\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published: string;\n  license: string;\n  licenseBox?: ReactNode;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  locale?: string;\n  copyEmbedLink?: string;\n  copySourceReference?: string;\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  license,\n  licenseBox,\n  published,\n  copyPageUrlLink,\n  printUrl,\n  locale,\n  copyEmbedLink,\n  copySourceReference,\n}: Props) => {\n  const { t } = useTranslation();\n\n  const copyLinkHandler = () => {\n    if (copyPageUrlLink) {\n      copyTextToClipboard(copyPageUrlLink);\n    }\n  };\n  const licenseRights = getLicenseByAbbreviation(license, locale).rights;\n\n  const copyLicense = () => {\n    if (copySourceReference) {\n      copyTextToClipboard(copySourceReference);\n    }\n  };\n  const copyEmbededLink = () => {\n    if (copyEmbedLink) {\n      copyTextToClipboard(copyEmbedLink);\n    }\n  };\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n  const showSecondaryContributors = suppliers.length > 0 && authors.length > 0;\n\n  const buttonId = 'popupUseContent';\n\n  return (\n    <Wrapper>\n      <div>\n        {t('article.lastUpdated')} {published}\n      </div>\n      {(showPrimaryContributors || licenseRights.length > 0) && (\n        <TextWrapper>\n          <LicenseByline licenseRights={licenseRights}>\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0\n                  ? t('article.authorsLabel', {\n                      names: renderContributors(authors, t),\n                      interpolation: { escapeValue: false },\n                    })\n                  : getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseByline>\n        </TextWrapper>\n      )}\n      {showSecondaryContributors && <TextWrapper>{getSuppliersText(suppliers, t)}</TextWrapper>}\n      <ButtonWrapper>\n        {licenseBox && (\n          <Modal\n            labelledBy={buttonId}\n            activateButton={\n              <ButtonV2 id={buttonId} size=\"small\" shape=\"pill\" variant=\"outline\">\n                {t('article.useContent')}\n              </ButtonV2>\n            }\n            backgroundColor=\"white\"\n            position=\"top\"\n            size=\"medium\">\n            {(onClose: () => void) => (\n              <>\n                <ModalHeader modifier=\"no-bottom-padding\">\n                  <ModalCloseButton onClick={onClose} title=\"Lukk\" />\n                </ModalHeader>\n                <ModalBody>{licenseBox}</ModalBody>\n              </>\n            )}\n          </Modal>\n        )}\n        {copySourceReference && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copySourceReference}\n            onClick={copyLicense}>\n            {`${t('license.copy')} ${t('license.copyTitle').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {copyPageUrlLink && (\n          <CopyButton\n            onClick={copyLinkHandler}\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            data-copy-string={copyPageUrlLink}\n            copyNode={t('article.copyPageLinkCopied')}>\n            {t('article.copyPageLink')}\n          </CopyButton>\n        )}\n        {copyEmbedLink && (\n          <CopyButton\n            size=\"small\"\n            shape=\"pill\"\n            variant=\"outline\"\n            aria-live=\"assertive\"\n            copyNode={t('license.hasCopiedTitle')}\n            data-copy-string={copyEmbedLink}\n            onClick={copyEmbededLink}>\n            {`${t('license.copy')}  ${t('license.tabs.embedlink').toLowerCase()}`}\n          </CopyButton>\n        )}\n        {printUrl && (\n          <ButtonV2 size=\"small\" shape=\"pill\" variant=\"outline\" onClick={() => printPage(printUrl)}>\n            {t('article.printPage')}\n          </ButtonV2>\n        )}\n      </ButtonWrapper>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
53
53
  var renderContributors = function renderContributors(contributors, t) {
54
54
  var contributorsArray = contributors.map(function (contributor, index) {
55
55
  if (index < 1) return contributor.name;
@@ -126,16 +126,7 @@ var ArticleByline = function ArticleByline(_ref) {
126
126
  }), showSecondaryContributors && (0, _jsxRuntime.jsx)(TextWrapper, {
127
127
  children: getSuppliersText(suppliers, t)
128
128
  }), (0, _jsxRuntime.jsxs)(ButtonWrapper, {
129
- children: [copySourceReference && (0, _jsxRuntime.jsx)(_button.CopyButton, {
130
- size: "small",
131
- variant: "outline",
132
- shape: "pill",
133
- "aria-live": "assertive",
134
- copyNode: t('license.hasCopiedTitle'),
135
- "data-copy-string": copySourceReference,
136
- onClick: copyLicense,
137
- children: "".concat(t('license.copy'), " ").concat(t('license.copyTitle').toLowerCase())
138
- }), licenseBox && (0, _jsxRuntime.jsx)(_modal["default"], {
129
+ children: [licenseBox && (0, _jsxRuntime.jsx)(_modal["default"], {
139
130
  labelledBy: buttonId,
140
131
  activateButton: (0, _jsxRuntime.jsx)(_button.ButtonV2, {
141
132
  id: buttonId,
@@ -160,6 +151,15 @@ var ArticleByline = function ArticleByline(_ref) {
160
151
  })]
161
152
  });
162
153
  }
154
+ }), copySourceReference && (0, _jsxRuntime.jsx)(_button.CopyButton, {
155
+ size: "small",
156
+ shape: "pill",
157
+ variant: "outline",
158
+ "aria-live": "assertive",
159
+ copyNode: t('license.hasCopiedTitle'),
160
+ "data-copy-string": copySourceReference,
161
+ onClick: copyLicense,
162
+ children: "".concat(t('license.copy'), " ").concat(t('license.copyTitle').toLowerCase())
163
163
  }), copyPageUrlLink && (0, _jsxRuntime.jsx)(_button.CopyButton, {
164
164
  onClick: copyLinkHandler,
165
165
  size: "small",
@@ -14,8 +14,8 @@ type Props = {
14
14
  onClose: () => void;
15
15
  };
16
16
  }) => ReactNode) | ReactNode | null;
17
- competenceGoalTypes?: string[];
17
+ competenceGoalsLoading?: boolean;
18
18
  children: ReactNode;
19
19
  };
20
- declare const ArticleHeaderWrapper: ({ children, competenceGoals, competenceGoalTypes }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
20
+ declare const ArticleHeaderWrapper: ({ children, competenceGoals, competenceGoalsLoading }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
21
21
  export default ArticleHeaderWrapper;
@@ -40,13 +40,13 @@ var CompetenceBadgeText = /*#__PURE__*/(0, _base["default"])("span", {
40
40
  } : {
41
41
  name: "x85wbw",
42
42
  styles: "padding:0 5px",
43
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QnVDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudFR5cGUsIFJlYWN0Tm9kZSwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgQ29tcGV0ZW5jZUdvYWxzRGlhbG9nIGZyb20gJy4uL0NvbXBldGVuY2VHb2Fscy9Db21wZXRlbmNlR29hbHNEaWFsb2cnO1xuXG5jb25zdCBjbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdhcnRpY2xlJyxcbiAgcHJlZml4OiAnYy0nLFxufSk7XG5cbmNvbnN0IENvbXBldGVuY2VCYWRnZVRleHQgPSBzdHlsZWQuc3BhbmBcbiAgcGFkZGluZzogMCA1cHg7XG5gO1xuXG50eXBlIFByb3BzID0ge1xuICBjb21wZXRlbmNlR29hbHM/OlxuICAgIHwgKChpbnA6IHsgRGlhbG9nOiBDb21wb25lbnRUeXBlOyBkaWFsb2dQcm9wczogeyBpc09wZW46IGJvb2xlYW47IG9uQ2xvc2U6ICgpID0+IHZvaWQgfSB9KSA9PiBSZWFjdE5vZGUpXG4gICAgfCBSZWFjdE5vZGVcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2FsVHlwZXM/OiBzdHJpbmdbXTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IEFydGljbGVIZWFkZXJXcmFwcGVyID0gKHsgY2hpbGRyZW4sIGNvbXBldGVuY2VHb2FscywgY29tcGV0ZW5jZUdvYWxUeXBlcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbaXNPcGVuLCBzZXRJc09wZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNNb2JpbGUpIHtcbiAgICAgIGNvbnN0IGhlcm9Db250ZW50TGlzdDogTm9kZUxpc3RPZjxIVE1MRWxlbWVudD4gPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCcuYy1hcnRpY2xlX19oZWFkZXInKTtcbiAgICAgIGlmIChoZXJvQ29udGVudExpc3QubGVuZ3RoID09PSAxKSB7XG4gICAgICAgIGhlcm9Db250ZW50TGlzdFswXS5zY3JvbGxJbnRvVmlldyh0cnVlKTtcbiAgICAgICAgd2luZG93LnNjcm9sbEJ5KDAsIGhlcm9Db250ZW50TGlzdFswXS5vZmZzZXRUb3AgLSAxMjApOyAvLyBBZGp1c3QgZm9yIGhlYWRlclxuICAgICAgfVxuICAgIH1cbiAgfSwgW10pO1xuXG4gIGNvbnN0IG9wZW5EaWFsb2cgPSAoKSA9PiB7XG4gICAgc2V0SXNPcGVuKHRydWUpO1xuICB9O1xuXG4gIGNvbnN0IGNsb3NlRGlhbG9nID0gKCkgPT4ge1xuICAgIHNldElzT3BlbihmYWxzZSk7XG4gIH07XG5cbiAgaWYgKCFjb21wZXRlbmNlR29hbHMpIHtcbiAgICByZXR1cm4gPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PntjaGlsZHJlbn08L2Rpdj47XG4gIH1cblxuICBjb25zdCBkaWFsb2cgPVxuICAgIHR5cGVvZiBjb21wZXRlbmNlR29hbHMgPT09ICdmdW5jdGlvbicgPyAoXG4gICAgICBjb21wZXRlbmNlR29hbHMoe1xuICAgICAgICBEaWFsb2c6IENvbXBldGVuY2VHb2Fsc0RpYWxvZyxcbiAgICAgICAgZGlhbG9nUHJvcHM6IHtcbiAgICAgICAgICBpc09wZW46IGlzT3BlbixcbiAgICAgICAgICBvbkNsb3NlOiBjbG9zZURpYWxvZyxcbiAgICAgICAgfSxcbiAgICAgIH0pXG4gICAgKSA6IChcbiAgICAgIDxDb21wZXRlbmNlR29hbHNEaWFsb2cgb25DbG9zZT17Y2xvc2VEaWFsb2d9IGlzT3Blbj17aXNPcGVufT5cbiAgICAgICAge2NvbXBldGVuY2VHb2Fsc31cbiAgICAgIDwvQ29tcGV0ZW5jZUdvYWxzRGlhbG9nPlxuICAgICk7XG4gIHJldHVybiAoXG4gICAgPGRpdiB7Li4uY2xhc3NlcygnaGVhZGVyJyl9PlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPEJ1dHRvblYyIHNpemU9XCJ4c21hbGxcIiBjb2xvclRoZW1lPVwibGlnaHRcIiBzaGFwZT1cInBpbGxcIiBvbkNsaWNrPXtvcGVuRGlhbG9nfT5cbiAgICAgICAgPEZvb3RlckhlYWRlckljb24gLz5cbiAgICAgICAgPENvbXBldGVuY2VCYWRnZVRleHQ+e3QoJ2NvbXBldGVuY2VHb2Fscy5zaG93Q29tcGV0ZW5jZUdvYWxzJyl9PC9Db21wZXRlbmNlQmFkZ2VUZXh0PlxuICAgICAgPC9CdXR0b25WMj5cbiAgICAgIHtkaWFsb2d9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBcnRpY2xlSGVhZGVyV3JhcHBlcjtcbiJdfQ== */",
43
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QnVDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudFR5cGUsIFJlYWN0Tm9kZSwgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgaXNNb2JpbGUgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgRm9vdGVySGVhZGVySWNvbiB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgQ29tcGV0ZW5jZUdvYWxzRGlhbG9nIGZyb20gJy4uL0NvbXBldGVuY2VHb2Fscy9Db21wZXRlbmNlR29hbHNEaWFsb2cnO1xuXG5jb25zdCBjbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdhcnRpY2xlJyxcbiAgcHJlZml4OiAnYy0nLFxufSk7XG5cbmNvbnN0IENvbXBldGVuY2VCYWRnZVRleHQgPSBzdHlsZWQuc3BhbmBcbiAgcGFkZGluZzogMCA1cHg7XG5gO1xuXG50eXBlIFByb3BzID0ge1xuICBjb21wZXRlbmNlR29hbHM/OlxuICAgIHwgKChpbnA6IHsgRGlhbG9nOiBDb21wb25lbnRUeXBlOyBkaWFsb2dQcm9wczogeyBpc09wZW46IGJvb2xlYW47IG9uQ2xvc2U6ICgpID0+IHZvaWQgfSB9KSA9PiBSZWFjdE5vZGUpXG4gICAgfCBSZWFjdE5vZGVcbiAgICB8IG51bGw7XG4gIGNvbXBldGVuY2VHb2Fsc0xvYWRpbmc/OiBib29sZWFuO1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xufTtcblxuY29uc3QgQXJ0aWNsZUhlYWRlcldyYXBwZXIgPSAoeyBjaGlsZHJlbiwgY29tcGV0ZW5jZUdvYWxzLCBjb21wZXRlbmNlR29hbHNMb2FkaW5nIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc09wZW4sIHNldElzT3Blbl0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChpc01vYmlsZSkge1xuICAgICAgY29uc3QgaGVyb0NvbnRlbnRMaXN0OiBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5jLWFydGljbGVfX2hlYWRlcicpO1xuICAgICAgaWYgKGhlcm9Db250ZW50TGlzdC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgaGVyb0NvbnRlbnRMaXN0WzBdLnNjcm9sbEludG9WaWV3KHRydWUpO1xuICAgICAgICB3aW5kb3cuc2Nyb2xsQnkoMCwgaGVyb0NvbnRlbnRMaXN0WzBdLm9mZnNldFRvcCAtIDEyMCk7IC8vIEFkanVzdCBmb3IgaGVhZGVyXG4gICAgICB9XG4gICAgfVxuICB9LCBbXSk7XG5cbiAgY29uc3Qgb3BlbkRpYWxvZyA9ICgpID0+IHtcbiAgICBzZXRJc09wZW4odHJ1ZSk7XG4gIH07XG5cbiAgY29uc3QgY2xvc2VEaWFsb2cgPSAoKSA9PiB7XG4gICAgc2V0SXNPcGVuKGZhbHNlKTtcbiAgfTtcblxuICBpZiAoIWNvbXBldGVuY2VHb2Fscykge1xuICAgIHJldHVybiA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+e2NoaWxkcmVufTwvZGl2PjtcbiAgfVxuXG4gIGNvbnN0IGRpYWxvZyA9XG4gICAgdHlwZW9mIGNvbXBldGVuY2VHb2FscyA9PT0gJ2Z1bmN0aW9uJyA/IChcbiAgICAgIGNvbXBldGVuY2VHb2Fscyh7XG4gICAgICAgIERpYWxvZzogQ29tcGV0ZW5jZUdvYWxzRGlhbG9nLFxuICAgICAgICBkaWFsb2dQcm9wczoge1xuICAgICAgICAgIGlzT3BlbjogaXNPcGVuLFxuICAgICAgICAgIG9uQ2xvc2U6IGNsb3NlRGlhbG9nLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApIDogKFxuICAgICAgPENvbXBldGVuY2VHb2Fsc0RpYWxvZyBvbkNsb3NlPXtjbG9zZURpYWxvZ30gaXNPcGVuPXtpc09wZW59PlxuICAgICAgICB7Y29tcGV0ZW5jZUdvYWxzfVxuICAgICAgPC9Db21wZXRlbmNlR29hbHNEaWFsb2c+XG4gICAgKTtcbiAgcmV0dXJuIChcbiAgICA8ZGl2IHsuLi5jbGFzc2VzKCdoZWFkZXInKX0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8QnV0dG9uVjJcbiAgICAgICAgYXJpYS1idXN5PXtjb21wZXRlbmNlR29hbHNMb2FkaW5nfVxuICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgY29sb3JUaGVtZT1cImxpZ2h0XCJcbiAgICAgICAgc2hhcGU9XCJwaWxsXCJcbiAgICAgICAgb25DbGljaz17b3BlbkRpYWxvZ31cbiAgICAgICAgZGlzYWJsZWQ9e2NvbXBldGVuY2VHb2Fsc0xvYWRpbmd9PlxuICAgICAgICA8Rm9vdGVySGVhZGVySWNvbiAvPlxuICAgICAgICA8Q29tcGV0ZW5jZUJhZGdlVGV4dD57dCgnY29tcGV0ZW5jZUdvYWxzLnNob3dDb21wZXRlbmNlR29hbHMnKX08L0NvbXBldGVuY2VCYWRnZVRleHQ+XG4gICAgICA8L0J1dHRvblYyPlxuICAgICAge2RpYWxvZ31cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEFydGljbGVIZWFkZXJXcmFwcGVyO1xuIl19 */",
44
44
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
45
45
  });
46
46
  var ArticleHeaderWrapper = function ArticleHeaderWrapper(_ref) {
47
47
  var children = _ref.children,
48
48
  competenceGoals = _ref.competenceGoals,
49
- competenceGoalTypes = _ref.competenceGoalTypes;
49
+ competenceGoalsLoading = _ref.competenceGoalsLoading;
50
50
  var _useState = (0, _react.useState)(false),
51
51
  _useState2 = _slicedToArray(_useState, 2),
52
52
  isOpen = _useState2[0],
@@ -86,10 +86,12 @@ var ArticleHeaderWrapper = function ArticleHeaderWrapper(_ref) {
86
86
  });
87
87
  return (0, _jsxRuntime.jsxs)("div", _objectSpread(_objectSpread({}, classes('header')), {}, {
88
88
  children: [children, (0, _jsxRuntime.jsxs)(_button.ButtonV2, {
89
+ "aria-busy": competenceGoalsLoading,
89
90
  size: "xsmall",
90
91
  colorTheme: "light",
91
92
  shape: "pill",
92
93
  onClick: openDialog,
94
+ disabled: competenceGoalsLoading,
93
95
  children: [(0, _jsxRuntime.jsx)(_common.FooterHeaderIcon, {}), (0, _jsxRuntime.jsx)(CompetenceBadgeText, {
94
96
  children: t('competenceGoals.showCompetenceGoals')
95
97
  })]
@@ -5,9 +5,18 @@ type ImageProps = {
5
5
  type BannerProps = {
6
6
  link: string;
7
7
  image: ImageProps;
8
- title: string;
9
- content: string;
10
- linkText: string;
8
+ title: {
9
+ title: string;
10
+ lang?: string;
11
+ };
12
+ content: {
13
+ content: string;
14
+ lang?: string;
15
+ };
16
+ linkText: {
17
+ text: string;
18
+ lang?: string;
19
+ };
11
20
  };
12
21
  export declare const BannerCard: ({ link, title, content, linkText, image }: BannerProps) => import("@emotion/react/jsx-runtime").JSX.Element;
13
22
  export default BannerCard;